1 #include "Offer_Importer.h"
3 TAO_Offer_Importer::TAO_Offer_Importer (CosTrading::Lookup_ptr lookup_if
,
4 CORBA::Boolean verbose
)
11 TAO_Offer_Importer::perform_queries (void)
13 ACE_DEBUG ((LM_DEBUG
, "*** TAO_Offer_Importer::Federated Query.\n"));
15 TAO_Policy_Creator policies
;
16 policies
.exact_type_match (0);
17 policies
.search_card (16*NUM_OFFERS
);
18 policies
.match_card (16*NUM_OFFERS
);
19 policies
.return_card (16*NUM_OFFERS
);
20 policies
.link_follow_rule (CosTrading::always
);
21 this->perform_queries_with_policies (policies
);
25 TAO_Offer_Importer::perform_directed_queries (void)
27 ACE_DEBUG ((LM_DEBUG
, "*** TAO_Offer_Importer::Directed Query.\n"));
29 TAO_Policy_Creator policies
;
30 policies
.exact_type_match (0);
31 policies
.search_card (16*NUM_OFFERS
);
32 policies
.match_card (16*NUM_OFFERS
);
33 policies
.return_card (16*NUM_OFFERS
);
34 policies
.link_follow_rule (CosTrading::local_only
);
37 ACE_DEBUG ((LM_DEBUG
, "Obtaining link interface.\n"));
38 CosTrading::Link_var link_if
= this->lookup_
->link_if ();
42 ACE_DEBUG ((LM_DEBUG
, "Obtaining references to traders directly"
43 " linked to the root trader.\n"));
45 CosTrading::LinkNameSeq_var link_name_seq
= link_if
->list_links ();
47 if (link_name_seq
->length () > 0)
51 ACE_DEBUG ((LM_DEBUG
, "Getting link information for %C\n",
52 static_cast<const char*> (link_name_seq
[0u])));
55 CosTrading::Link::LinkInfo_var link_info
=
56 link_if
->describe_link (link_name_seq
[0u]);
58 CosTrading::Lookup_ptr lookup_if
= link_info
->target
.in ();
59 CosTrading::Link_var link_if2
= lookup_if
->link_if ();
61 CosTrading::LinkNameSeq_var link_name_seq2
= link_if2
->list_links ();
63 if (link_name_seq2
->length () > 0)
66 CORBA::ULong length
= link_name_seq2
->length ();
67 for (i
= 0; i
< length
; i
++)
69 if (ACE_OS::strcmp (link_name_seq2
[i
], "Bootstrap") != 0)
75 CosTrading::LinkName
* trader_name
=
76 CosTrading::TraderName::allocbuf (2);
78 ACE_DEBUG ((LM_DEBUG
, "*** Query through %C to destination %C.\n",
79 static_cast<const char*> (link_name_seq
[0u]),
80 static_cast<const char*> (link_name_seq2
[i
])));
82 trader_name
[0] = CORBA::string_dup (link_name_seq
[0u]);
83 trader_name
[1] = CORBA::string_dup (link_name_seq2
[i
]);
84 policies
.starting_trader (new CosTrading::TraderName
85 (2, 2, trader_name
, 1));
87 this->perform_queries_with_policies (policies
);
92 ACE_ERROR ((LM_ERROR
, ACE_TEXT("ERROR, This test requires a complete graph of three traders!\n")));
93 throw CORBA::BAD_INV_ORDER(); // Let outside world know we can't continue this way.
98 ACE_ERROR ((LM_ERROR
, ACE_TEXT("ERROR, This test requires a complete graph of three traders!\n")));
99 throw CORBA::BAD_INV_ORDER(); // Let outside world know we can't continue this way.
105 TAO_Offer_Importer::perform_queries_with_policies (
106 const TAO_Policy_Creator
& policies
111 CosTrading::Lookup::SpecifiedProps desired_props
;
115 (char*) TT_Info::REMOTE_IO_PROPERTY_NAMES
[TT_Info::NAME
],
116 (char*) TT_Info::REMOTE_IO_PROPERTY_NAMES
[TT_Info::DESCRIPTION
],
117 (char*) TT_Info::REMOTE_IO_PROPERTY_NAMES
[TT_Info::LOCATION
],
118 (char*) TT_Info::REMOTE_IO_PROPERTY_NAMES
[TT_Info::HOST_NAME
]
121 CosTrading::PropertyNameSeq
prop_name_seq (4, 4, props
, 0);
122 desired_props
.prop_names (prop_name_seq
);
124 for (int i
= 0; i
< TT_Info::NUM_QUERIES
; i
++)
126 ACE_DEBUG ((LM_DEBUG
, "\n"));
127 ACE_DEBUG ((LM_DEBUG
, "*** Performing query for %C.\n", TT_Info::QUERIES
[i
][0]));
128 ACE_DEBUG ((LM_DEBUG
, "*** Query: %C\n", TT_Info::QUERIES
[i
][1]));
129 ACE_DEBUG ((LM_DEBUG
, "*** Preferences: %C\n", TT_Info::QUERIES
[i
][2]));
130 CosTrading::OfferSeq_var offer_seq
;
131 CosTrading::OfferIterator_var offer_iterator
;
132 CosTrading::PolicyNameSeq_var limits_applied
;
134 // Test with different how_many amount, both should work.
135 // Initially try to get this amount in the sequence.
136 CORBA::ULong how_many
= 8;
139 how_many
=0; // 0: Don't retrieve in offers but all in iterator.
142 this->lookup_
->query (TT_Info::QUERIES
[i
][0],
143 TT_Info::QUERIES
[i
][1],
144 TT_Info::QUERIES
[i
][2],
145 policies
.policy_seq (),
149 offer_iterator
.out(),
150 limits_applied
.out());
152 CORBA::ULong seqlen
= (offer_seq
.ptr() == 0 ? 0 :
153 offer_seq
->length ());
154 CORBA::ULong itrlen
= (CORBA::is_nil(offer_iterator
.in()) ? 0 :
155 offer_iterator
->max_left ());
156 CORBA::ULong total
= seqlen
+ itrlen
;
157 CORBA::ULong expected
= ACE_OS::atoi (TT_Info::QUERIES
[i
][3]);
159 if (total
!= expected
)
162 ,"ERROR: Expected %d for query %d, got seq(%d) + itr(%d) = %d\n"
169 throw CORBA::TRANSIENT(); // Try again later?
171 else if (this->verbose_
)
174 ,"Expected %d for query %d, got seq(%d) + itr(%d) = %d\n"
185 ACE_DEBUG ((LM_DEBUG
, "*** Results:\n\n"));
186 this->display_results (*offer_seq
.ptr(),
187 offer_iterator
.in());
189 if (limits_applied
->length () > 0)
190 ACE_DEBUG ((LM_DEBUG
, "*** Limits Applied:\n\n"));
192 for (int length
= limits_applied
->length (), j
= 0; j
< length
; j
++)
194 const char *policy_name
= (*limits_applied
.ptr())[j
];
195 ACE_DEBUG ((LM_DEBUG
, "%C\n",
196 static_cast<const char*> (policy_name
)));
201 catch (const CORBA::Exception
& e
)
203 e
._tao_print_exception ("TAO_Offer_Importer::perform_queries_with_policies");
209 TAO_Offer_Importer::display_results (const CosTrading::OfferSeq
& offer_seq
,
210 CosTrading::OfferIterator_ptr offer_iterator
) const
214 ACE_DEBUG ((LM_DEBUG
, "------------------------------\n"));
215 ACE_DEBUG ((LM_DEBUG
, "Offers in the sequence:\n"));
216 ACE_DEBUG ((LM_DEBUG
, "------------------------------\n"));
217 for (CORBA::ULong i
= 0; i
< offer_seq
.length (); i
++)
219 // Call back to the exported object.
220 // FIXME: shouldn't this be done in a separate 'verify_results' method?
221 // (confirm () now skipped in quiet mode)
222 TAO_Trader_Test::Remote_Output_var remote_output
=
223 TAO_Trader_Test::Remote_Output::_narrow (offer_seq
[i
].reference
.in ());
225 remote_output
->confirm ();
227 TT_Info::dump_properties (offer_seq
[i
].properties
, 1);
228 ACE_DEBUG ((LM_DEBUG
, "------------------------------\n"));
231 ACE_DEBUG ((LM_DEBUG
, " Offers in the iterator:\n"));
232 ACE_DEBUG ((LM_DEBUG
, "------------------------------\n"));
233 if (! CORBA::is_nil (offer_iterator
))
235 CORBA::Boolean any_left
= 0;
238 CosTrading::OfferSeq_var offers
;
239 // Use of iterator->max_left() to get all iterator results is not
240 // recommended? (see p.879 Advanced CORBA programming book)
241 // Howmany to process is a choice between next_n call 'dispatch
242 // costs' and 'larges results marshalling bandwidth costs'.
243 CORBA::ULong how_many
= 100;
244 any_left
= offer_iterator
->next_n (how_many
, offers
.out());
246 for (CORBA::ULong i
= 0; i
< offers
->length (); i
++)
248 // Call back to the exported object.
249 // FIXME: shouldn't this be done in a separate 'verify_results' method?
250 // (confirm () now skipped in quiet mode)
251 TAO_Trader_Test::Remote_Output_var remote_output
=
252 TAO_Trader_Test::Remote_Output::_narrow ((*offers
)[i
].reference
.in ());
254 remote_output
->confirm ();
256 CosTrading::PropertySeq
& props
= (*offers
)[i
].properties
;
257 TT_Info::dump_properties (props
, 1);
259 ACE_DEBUG ((LM_DEBUG
, "------------------------------\n"));
264 offer_iterator
->destroy ();
267 catch (const CORBA::Exception
& e
)
269 e
._tao_print_exception ("TAO_Offer_Importer::display_results");