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
|
// **********************************************************************
//
// Copyright (c) 2003-2009 ZeroC, Inc. All rights reserved.
//
// This copy of Ice is licensed to you under the terms described in the
// ICE_LICENSE file included in this distribution.
//
// **********************************************************************
#include <Ice/Ice.h>
#include <Ice/SliceChecksums.h>
#include <TestCommon.h>
#include <Test.h>
using namespace std;
Test::ChecksumPrx
allTests(const Ice::CommunicatorPtr& communicator, bool collocated)
{
string ref = "test:default -p 12010 -t 10000";
Ice::ObjectPrx base = communicator->stringToProxy(ref);
test(base);
Test::ChecksumPrx checksum = Test::ChecksumPrx::checkedCast(base);
test(checksum);
Ice::SliceChecksumDict::const_iterator p;
//
// Verify that no checksums are present for local types.
//
cout << "testing checksums... " << flush;
Ice::SliceChecksumDict localChecksums = Ice::sliceChecksums();
test(!localChecksums.empty());
for(p = localChecksums.begin(); p != localChecksums.end(); ++p)
{
string::size_type pos = p->first.find("Local");
test(pos == string::npos);
}
//
// Get server's Slice checksums.
//
Ice::SliceChecksumDict d = checksum->getSliceChecksums();
//
// Compare the checksums. For a type FooN whose name ends in an integer N,
// we assume that the server's type does not change for N = 1, and does
// change for N > 1.
//
for(p = d.begin(); p != d.end(); ++p)
{
int n = 0;
string::size_type pos = p->first.find_first_of("0123456789");
if(pos != string::npos)
{
n = atoi(p->first.c_str() + pos);
}
Ice::SliceChecksumDict::const_iterator q = localChecksums.find(p->first);
test(q != localChecksums.end());
if(n <= 1)
{
test(q->second == p->second);
}
else
{
test(q->second != p->second);
}
}
cout << "ok" << endl;
return checksum;
}
|