summaryrefslogtreecommitdiff
path: root/TAO/orbsvcs/tests/EC_Config/Test.cpp
blob: 2941938a70ba798eec8014bd3d791df0a9417ef6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
// $Id$

#include "ace/Array.h"
#include "ace/Bound_Ptr.h"
#include "ace/Synch.h"
#include "ACEXML/parser/parser/Parser.h"
#include "ACEXML/common/InputSource.h"
#include "ACEXML/common/FileCharStream.h"
#include "ACEXML/common/DefaultHandler.h"

#include "ECConfig.h"
#include "Config_Factory.h"
#include "Test_Handler.h"

using namespace TestConfig;

//NOTE: Read from a formatted file rather than hardcode the configuration. Check ACE_XML.

int
main (int argc, char *argv[])
{
  int retval = 0;

  ACEXML_TRY_NEW_ENV
    {
      ACEXML_Parser parser;

      // TODO parse args for config filename

      ACEXML_Char *filename = ACE_LIB_TEXT("test.xml");
      ACEXML_FileCharStream fcs;
      if ((retval = fcs.open(filename)) != 0) {
        ACE_DEBUG ((LM_DEBUG, "Could not open file %s\n",filename));
        return retval;
      }

      ACEXML_InputSource is (&fcs);

      Test_Handler handler (filename);
      ACEXML_DefaultHandler dflt;

      parser.setContentHandler (&handler);
      parser.setDTDHandler (&dflt);
      parser.setErrorHandler (&handler);
      parser.setEntityResolver (&dflt);

      parser.parse(&is);
      ACEXML_TRY_CHECK;

      ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("Finished parsing\n")));

      // TODO configure according to parsed XML
      ConfigFactory::Default_Config_Factory fact;
      fact.init(argc,argv);

      Test_Config *backend = fact.create_testconfig();
      if (0 == backend) {
        ACE_DEBUG((LM_DEBUG, "Error: could not create back end!\n"));
        return 1;
      }

      // PROBLEM: occasional segfault on run and configure
      TCFG_SET_WPTR cfg_ptr(handler.get_configs());

      int retval = 0;
      if ((retval = backend->configure(cfg_ptr)) != 0) {
        ACE_DEBUG((LM_DEBUG, "Error configuring back end! (%d)\n",retval));
        return retval;
      }

      if ((retval = backend->run()) != 0) {
        ACE_DEBUG((LM_DEBUG, "Error running back end! (%d)\n",retval));
        return retval;
      }

      fact.destroy_testconfig(backend);
      fact.fini();

    }
  ACEXML_CATCH (ACEXML_SAXException, ex)
    {
      ACE_DEBUG ((LM_ERROR, ACE_TEXT ("Exception occurred: %s. Exiting...\n"),
                  ex.message()));
      return 1;
    }
  ACEXML_ENDTRY;

  ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("Finished successfully\n")));

  return retval;
}