summaryrefslogtreecommitdiff
path: root/TAO/tests/POA/On_Demand_Act_Direct_Coll/test_i.cpp
blob: 41cd3c13348ba8118d43062a1c069aa7940807a4 (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
// $Id$

#include "test_i.h"
#include "ace/OS_NS_unistd.h"
#include "ace/OS_NS_string.h"

// Constructor
test_i::test_i (CORBA::ORB_ptr orb,
                PortableServer::POA_ptr poa,
                ACE_thread_t thrid)
  : orb_ (CORBA::ORB::_duplicate (orb))
   ,poa_ (PortableServer::POA::_duplicate (poa))
   ,thr_id_ (thrid)
{
}

void
test_i::method (void)
{
}

char *
test_i::get_string (void)
{
  ACE_DEBUG ((LM_DEBUG,
              "(%P|%t) Upcall in process ..\n"));
  // Use portable thread IDs
  ACE_Thread_ID self_ID;
  // Thread ID from Server
  ACE_Thread_ID this_ID;
  this_ID.id(this->thr_id_);

  // Servant Thread ID same as Thread ID server, so a remote call,
  // in case of a collocation the servant runs in calling thread (Client)
  if (self_ID == this_ID)
    {
      ACE_ERROR ((LM_ERROR,
                 "(%P|%t) ERROR: A remote call has been made "
                       " exiting ..\n"));
      ACE_OS::abort ();
    }
  else
    {
      ACE_DEBUG ((LM_DEBUG,
                "(%P|%t) OK: A collocated invocation has been made.\n"));
    }
  return CORBA::string_dup ("Hello there!");
}

void
test_i::shutdown (void)
{
  // Give the client thread time to return from the collocated
  // call to this method before shutting down the ORB.  We sleep
  // to avoid BAD_INV_ORDER exceptions on fast dual processor machines.
  ACE_OS::sleep (1);
  this->orb_->shutdown (0);
}