* </pre>
*/
public void testSubscription3() throws Exception
{
PublishSession publishSession = new PublishSession(getBobPhone());
Request publish = publishSession.newPublish(getClass().getResourceAsStream("publish1.xml"), 60); // 1
publishSession.sendRequest(publish, SipResponse.OK); // 2
SubscribeSession presenceSession = new SubscribeSession(getAlicePhone(), "presence");
Request subscribe = presenceSession.newInitialSubscribe(100, getBobUri()); // 3
presenceSession.sendRequest(subscribe, Response.OK); // 4
ServerTransaction tx = presenceSession.waitForNotify(); // 5
//System.out.println("3:\n" + tx.getRequest());
presenceSession.sendResponse(Response.OK, tx); // 6
Presence presence = getPresence(tx.getRequest());
assertEquals(Basic.OPEN, presence.getTupleArray()[0].getStatus().getBasic());
SubscribeSession winfoSession = new SubscribeSession(getBobPhone(), "presence.winfo"); // 7
subscribe = winfoSession.newInitialSubscribe(60, getBobUri());
winfoSession.sendRequest(subscribe, Response.OK); // 8
tx = winfoSession.waitForNotify(); // 9
Request notify = tx.getRequest();
//System.out.println(notify);
winfoSession.sendResponse(Response.OK, tx); // 10
SubscriptionStateHeader subState = (SubscriptionStateHeader) notify.getHeader(SubscriptionStateHeader.NAME);
assertEquals(SubscriptionStateHeader.ACTIVE.toLowerCase(), subState.getState().toLowerCase());
assertEquals(WatcherInfoEventPackage.NAME, ((EventHeader) notify.getHeader(EventHeader.NAME)).getEventType());
Watcherinfo watcherinfo = getWatcherinfo(notify);
assertEquals(0, watcherinfo.getVersion().intValue());
assertEquals(Watcherinfo.State.FULL, watcherinfo.getState());
assertEquals(1, watcherinfo.getWatcherListArray().length);
WatcherList watcherList = watcherinfo.getWatcherListArray(0);
assertEquals(getBobUri(), watcherList.getResource());
assertEquals(PresenceEventPackage.NAME, watcherList.getPackage());
assertEquals(1, watcherList.getWatcherArray().length);
Watcher watcher = watcherList.getWatcherArray(0);
assertEquals(Event.SUBSCRIBE, watcher.getEvent());
assertEquals(getAliceUri(), watcher.getStringValue());
assertEquals(Status.ACTIVE, watcher.getStatus());
HttpClient httpClient = new HttpClient();
PutMethod put = new PutMethod(getHttpXcapUri() + BOB_PRES_RULES_URI); // 11
InputStream is = WatcherInfoTest.class.getResourceAsStream("/xcap-root/pres-rules/users/put/elementPoliteBlock.xml");
RequestEntity entity = new InputStreamRequestEntity(is, "application/xcap-el+xml");
put.setRequestEntity(entity);
int result = httpClient.executeMethod(put);
assertEquals(200, result); // 12
put.releaseConnection();
tx = presenceSession.waitForNotify(); // 13
//System.out.println("11:\n" + tx.getRequest());
presenceSession.sendResponse(Response.OK, tx); // 14
presence = getPresence(tx.getRequest());
assertEquals(Basic.CLOSED, presence.getTupleArray()[0].getStatus().getBasic());
tx = winfoSession.waitForNotify(); // 15
notify = tx.getRequest();
winfoSession.sendResponse(Response.OK, tx); // 16
System.out.println(notify);
subState = (SubscriptionStateHeader) notify.getHeader(SubscriptionStateHeader.NAME);
assertEquals(SubscriptionStateHeader.ACTIVE.toLowerCase(), subState.getState().toLowerCase());
assertEquals(WatcherInfoEventPackage.NAME, ((EventHeader) notify.getHeader(EventHeader.NAME)).getEventType());
watcherinfo = getWatcherinfo(notify);
assertEquals(1, watcherinfo.getVersion().intValue());
assertEquals(Watcherinfo.State.FULL, watcherinfo.getState());
assertEquals(1, watcherinfo.getWatcherListArray().length);
watcherList = watcherinfo.getWatcherListArray(0);