本文整理匯總了C++中CuAssert函數的典型用法代碼示例。如果您正苦於以下問題:C++ CuAssert函數的具體用法?C++ CuAssert怎麽用?C++ CuAssert使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了CuAssert函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。
示例1: testRecvFail
static void testRecvFail(CuTest *tc) {
NTPSock*listenSock;
NTPSock*connectSock;
NTPSock*acceptSock;
char buf[20];
int result;
uint16_t port = 38712;
//connect the sockets
connectUtil(tc, &listenSock, &connectSock, &acceptSock, port);
//close one socket
NTPDisconnect(&connectSock);
CuAssert(tc, "disconnect to NULL", connectSock==NULL);
//try to recv() on the other socket
result = NTPRecv(acceptSock, buf, sizeof(buf));
CuAssert(tc, "recv should fail", result<=0);
//cleanup
NTPDisconnect(&listenSock);
NTPDisconnect(&acceptSock);
CuAssert(tc, "disconnect NULL", listenSock==NULL);
CuAssert(tc, "disconnect NULL", acceptSock==NULL);
}
示例2: TestSetThreadCount
int TestSetThreadCount(CuTest *ct) { /* SKIP */
/* Run this test only when hash is supported. */
#ifdef HAVE_HASH
DB_ENV *dbenv;
DB *db;
CuAssert(ct, "db_env_create", db_env_create(&dbenv, 0) == 0);
dbenv->set_errpfx(dbenv, "TestSetThreadCount");
CuAssert(ct, "set_thread_count", dbenv->set_thread_count(dbenv, 2) == 0);
CuAssert(ct, "env->open", dbenv->open(dbenv, ".",
DB_CREATE | DB_INIT_LOCK | DB_INIT_LOG | DB_INIT_MPOOL |
DB_INIT_TXN | DB_PRIVATE | DB_THREAD, 0) == 0);
CuAssert(ct, "db_create", db_create(&db, dbenv, 0) == 0);
CuAssert(ct, "DB->open", db->open(
db, NULL, NULL, "TestSetThreadCount", DB_HASH, DB_CREATE, 0) == 0);
db->close(db, 0);
dbenv->close(dbenv, 0);
#else
printf("TestSetThreadCount is not supported by the build.\n");
#endif /* HAVE_HASH */
return (0);
}
示例3: t_file___write_block
/*
* To verify the integrity of the output file produced
* I hand walked through the complete file ensuring that
* it held to the file schema--Bill
*/
void t_file___write_block(CuTest *tc) {
FILE *fp, *f;
m_uword cnt;
m_uword tmp;
int i, j;
m_file_block block;
miniat *m;
m = malloc(sizeof(miniat));
fp = fopen("write_block.miniat", "w+");
CuAssert(tc, "File pointer not equal to NULL", fp != NULL);
/*write the header*/
cnt = (rand() % 20) + 10;
m_file_write_block_count (m, fp, cnt);
/*start building the body data to write*/
for(i=0; i<cnt; i++) {
block.number = i;
block.id = (rand() % m_block_type_cnt);
block.start_address = ((rand() << 16) | (rand()));
block.length = rand()%32;
block.data = (m_uword *)malloc(sizeof(m_uword) * block.length);
CuAssert(tc, "Block data not equal to NULL", block.data != NULL);
/*make some data*/
for(j=0; j < block.length; j++) {
block.data[j] = ((rand() << 16) | (rand()));
}
/*write the block*/
m_file_write_block (m, fp, &block);
/*free the block.data*/
if(block.data) {
for(j=0; j < block.length; j++) {
//free(block.data[j]);
}
//free(block.data);
block.data = NULL;
}
}
/*rewind the file pointer and read the blocks to verify*/
rewind(fp);
/*check the counts*/
m_file_read_block_count (m, fp, &tmp);
CuAssert(tc, "Block count matches previous block count", cnt == tmp);
if(fp) {
fclose(fp);
}
if(m) {
free(m);
}
remove("write_block.miniat");
return;
}
示例4: testSendFail
static void testSendFail(CuTest *tc) {
NTPSock *listenSock;
NTPSock *connectSock;
NTPSock *acceptSock;
char buf[] = "So remember, remember the Red River Valley";
int result;
uint16_t port = 23551;
//connect the sockets
connectUtil(tc, &listenSock, &connectSock, &acceptSock, port);
//close one socket
NTPDisconnect(&acceptSock);
CuAssert(tc, "disconnect to NULL", acceptSock==NULL);
//try to send() on the other socket. Keep trying
//because it doesn't always fail the first time.
int i;
for(i=0;i<20;i++) {
result = NTPSend(connectSock, buf, NTPstrlen(buf));
}
CuAssert(tc, "Send should fail", result<=0);
//cleanup
NTPDisconnect(&listenSock);
NTPDisconnect(&connectSock);
CuAssert(tc, "disconnect NULL", listenSock==NULL);
CuAssert(tc, "disconnect NULL", acceptSock==NULL);
}
示例5: testSerializePublicationsFile
static void testSerializePublicationsFile(CuTest *tc) {
int res;
KSI_PublicationsFile *pubFile = NULL;
char *raw = NULL;
unsigned raw_len = 0;
FILE *f = NULL;
int symbol = 0;
unsigned i= 0;
KSI_ERR_clearErrors(ctx);
setFileMockResponse(tc, getFullResourcePath(TEST_PUBLICATIONS_FILE));
res = KSI_PublicationsFile_fromFile(ctx, getFullResourcePath(TEST_PUBLICATIONS_FILE), &pubFile);
CuAssert(tc, "Unable to read publications file", res == KSI_OK && pubFile != NULL);
res = KSI_PublicationsFile_serialize(ctx, pubFile, &raw, &raw_len);
CuAssert(tc, "Unable to serialize publications file", res == KSI_OK && raw != NULL && raw_len != 0);
f = fopen(getFullResourcePath(TEST_PUBLICATIONS_FILE), "rb");
CuAssert(tc, "Unable to open publications file", res == KSI_OK && f != NULL);
while ((symbol = getc(f)) != EOF && i<raw_len){
CuAssert(tc, "Serialized publications file mismatch", (char)symbol == raw[i]);
i++;
}
CuAssert(tc, "Serialized publications file length mismatch", i == raw_len);
KSI_PublicationsFile_free(pubFile);
KSI_free(raw);
if (f) fclose(f);
}
示例6: expect_authentic
static void
expect_authentic (CuTest *tc,
const int expected_status,
SignedVotedBallot const svbs,
VoterRoll const vr,
BlankBallot const bb)
{
char *raw_ballot_box = 0;
CuAssert (tc,
(0 == expected_status ?
"VHTI_authenticate should have accepted valid input"
: "VHTI_authenticate should have rejected invalid input"),
expected_status == VHTI_authenticate (svbs, vr, bb, &raw_ballot_box));
if (0 != expected_status)
{
if (raw_ballot_box)
fprintf (stderr, "Hmm: `%s'\n", raw_ballot_box);
CuAssertPtrEquals (tc, NULL, raw_ballot_box);
}
else
{
CuAssertPtrNotNull (tc, raw_ballot_box);
CuAssert (tc,
"VHTI_authenticate should have returned a RawBallotBox",
0 == VHTI_validate (RAW_BALLOT_BOX, raw_ballot_box));
VHTI_free (raw_ballot_box);
}
}
示例7: testVerifySignatureWithUserPublication
static void testVerifySignatureWithUserPublication(CuTest *tc) {
int res;
KSI_Signature *sig = NULL;
const char pubStr[] = "AAAAAA-CTOQBY-AAMJYH-XZPM6T-UO6U6V-2WJMHQ-EJMVXR-JEAGID-2OY7P5-XFFKYI-QIF2LG-YOV7SO";
const char pubStr_bad[] = "AAAAAA-CT5VGY-AAPUCF-L3EKCC-NRSX56-AXIDFL-VZJQK4-WDCPOE-3KIWGB-XGPPM3-O5BIMW-REOVR4";
KSI_PublicationData *pubData = NULL;
KSI_PublicationData *pubData_bad = NULL;
KSI_ERR_clearErrors(ctx);
res = KSI_PublicationData_fromBase32(ctx, pubStr, &pubData);
CuAssert(tc, "Unable to parse publication string.", res == KSI_OK && pubData != NULL);
res = KSI_PublicationData_fromBase32(ctx, pubStr_bad, &pubData_bad);
CuAssert(tc, "Unable to parse publication string.", res == KSI_OK && pubData_bad != NULL);
res = KSI_Signature_fromFile(ctx, getFullResourcePath("resource/tlv/ok-sig-2014-04-30.1-extended.ksig"), &sig);
CuAssert(tc, "Unable to read signature from file.", res == KSI_OK && sig != NULL);
res = KSI_Signature_verifyWithPublication(sig, ctx, pubData);
CuAssert(tc, "Unable to verify signature with publication.", res == KSI_OK);
res = KSI_Signature_verifyWithPublication(sig, ctx, pubData_bad);
CuAssert(tc, "Unable to verify signature with publication.", res != KSI_OK);
KSI_PublicationData_free(pubData);
KSI_PublicationData_free(pubData_bad);
KSI_Signature_free(sig);
}
示例8: TestSessionKeyTableAPI
void TestSessionKeyTableAPI( CuTest* tc )
{
dssl_SessionKeyTable* tbl = NULL;
DSSL_Session* sess = NULL;
DSSL_SessionKeyData* kd = NULL;
tbl = dssl_SessionKT_Create( 100, TEST_CACHE_TIMEOUT );
CuAssert( tc, "SessionKeyTable object should be not NULL", tbl != NULL );
sess = (DSSL_Session*) malloc( sizeof( DSSL_Session ) );
CuAssert( tc, "DSSL_Session object should be not NULL", sess != NULL );
memset( sess, 0, sizeof(*sess) );
dssl_SessionKT_Add( tbl, sess );
CuAssertTrue( tc, tbl->count == 1 );
kd = dssl_SessionKT_Find( tbl, sess->session_id );
CuAssertTrue( tc, kd != NULL );
CuAssertTrue( tc, kd->refcount == 1 );
CuAssertTrue( tc, kd->released_time == 0 );
kd = NULL;
dssl_SessionKT_Release( tbl, sess->session_id );
ThreadSleep( (TEST_CACHE_TIMEOUT+1)*1000 );
dssl_SessionKT_CleanSessionCache( tbl );
CuAssertTrue( tc, tbl->count == 0 );
free( sess );
dssl_SessionKT_Destroy( tbl );
}
示例9: testExtractingNotExisting
static void testExtractingNotExisting(CuTest* tc) {
int res;
KSI_Signature *sig = NULL;
KSI_MultiSignature *ms = NULL;
KSI_DataHash *hsh = NULL;
KSI_ERR_clearErrors(ctx);
res = KSI_Signature_fromFile(ctx, getFullResourcePath(TEST_SIGNATURE_FILE), &sig);
CuAssert(tc, "Unable to read signature from file.", res == KSI_OK && sig != NULL);
res = KSI_MultiSignature_new(ctx, &ms);
CuAssert(tc, "Unable to create multi signature container.", res == KSI_OK && ms != NULL);
res = KSI_MultiSignature_add(ms, sig);
CuAssert(tc, "Unable to add signature to multi signature container.", res == KSI_OK);
KSI_Signature_free(sig);
sig = NULL;
KSITest_DataHash_fromStr(ctx, "01db27c0db0aebb8d3963c3a720985cedb600f91854cdb1e45ad631611c39284dd", &hsh);
res = KSI_MultiSignature_get(ms, hsh, &sig);
CuAssert(tc, "Get should fail with KSI_MULTISIG_NOT_FOUND", res == KSI_MULTISIG_NOT_FOUND && sig == NULL);
KSI_DataHash_free(hsh);
KSI_MultiSignature_free(ms);
KSI_Signature_free(sig);
}
示例10: testVerifyDocument
static void testVerifyDocument(CuTest *tc) {
int res;
unsigned char in[0x1ffff];
unsigned in_len = 0;
char doc[] = "LAPTOP";
FILE *f = NULL;
KSI_Signature *sig = NULL;
KSI_ERR_clearErrors(ctx);
f = fopen(getFullResourcePath(TEST_SIGNATURE_FILE), "rb");
CuAssert(tc, "Unable to open signature file.", f != NULL);
in_len = (unsigned)fread(in, 1, sizeof(in), f);
CuAssert(tc, "Nothing read from signature file.", in_len > 0);
fclose(f);
res = KSI_Signature_parse(ctx, in, in_len, &sig);
CuAssert(tc, "Failed to parse signature", res == KSI_OK && sig != NULL);
res = KSI_Signature_verifyDocument(sig, ctx, doc, strlen(doc));
CuAssert(tc, "Failed to verify valid document", res == KSI_OK);
res = KSI_Signature_verifyDocument(sig, ctx, doc, sizeof(doc));
CuAssert(tc, "Verification did not fail with expected error.", res == KSI_VERIFICATION_FAILURE);
KSI_Signature_free(sig);
}
示例11: potion_test_empty
void potion_test_empty(CuTest *T) {
PN empty = PN_TUP0();
CuAssert(T, "empty isn't a tuple", PN_IS_TUPLE(empty));
CuAssert(T, "empty isn't a ref", PN_IS_PTR(empty));
CuAssertIntEquals(T, "tuple length is off",
0, PN_INT(potion_send(empty, potion_str(P, "length"))));
}
示例12: potion_test_allocated
void potion_test_allocated(CuTest *T) {
struct PNMemory *M = P->mem;
void *prev = NULL;
void *scanptr = (void *)((char *)M->birth_lo + PN_ALIGN(sizeof(struct PNMemory), 8));
while ((PN)scanptr < (PN)M->birth_cur) {
if (((struct PNFwd *)scanptr)->fwd != POTION_FWD && ((struct PNFwd *)scanptr)->fwd != POTION_COPIED) {
if (((struct PNObject *)scanptr)->vt > PN_TUSER) {
vPN(Object) o = (struct PNObject *)scanptr;
fprintf(stderr, "error: scanning heap from %p to %p\n",
M->birth_lo, M->birth_cur);
fprintf(stderr, "%p in %s region\n", scanptr,
IS_GC_PROTECTED(scanptr) ? "protected"
: IN_BIRTH_REGION(scanptr) ? "birth"
: IN_OLDER_REGION(scanptr) ? "older"
: "gc");
fprintf(stderr, "%p { uniq:0x%08x vt:0x%08x ivars[0]:0x%08lx type:0x%x}\n",
scanptr, o->uniq, o->vt, o->ivars[0],
potion_type((PN)scanptr));
fprintf(stderr, "prev %p: size=%d, type:0x%x (%s)\n",
prev, potion_type_size(P, prev),
potion_type((PN)prev), AS_STR(PN_VTABLE(PN_TYPE((PN)prev))));
#ifdef DEBUG
//potion_dump_stack(P);
#endif
}
CuAssert(T, "wrong type for allocated object", ((struct PNObject *)scanptr)->vt <= PN_TUSER);
}
prev = scanptr;
scanptr = (void *)((char *)scanptr + potion_type_size(P, scanptr));
CuAssert(T, "allocated object goes beyond GC pointer", (PN)scanptr <= (PN)M->birth_cur);
}
}
示例13: createIndex
void createIndex(CuTest* tc, Directory* dir, bool multiSegment) {
WhitespaceAnalyzer whitespaceAnalyzer;
IndexWriter w(dir, &whitespaceAnalyzer, true);
w.setMergePolicy(_CLNEW LogDocMergePolicy());
Document doc;
for (int i = 0; i < 100; i++) {
createDocument(doc, i, 4);
w.addDocument(&doc);
if (multiSegment && (i % 10) == 0) {
w.flush();
}
}
if (!multiSegment) {
w.optimize();
}
w.close();
IndexReader* r = IndexReader::open(dir);
if (multiSegment) {
CuAssert(tc,_T("check is multi"), strcmp(r->getObjectName(),"MultiSegmentReader")==0);
} else {
CuAssert(tc,_T("check is segment"), strcmp(r->getObjectName(),"SegmentReader")==0);
}
r->close();
_CLDELETE(r);
}
示例14: addInput
static void addInput(CuTest *tc, KSI_BlockSigner *bs, int genMeta) {
int res = KSI_UNKNOWN_ERROR;
size_t i;
KSI_DataHash *hsh = NULL;
KSI_MetaData *md = NULL;
for (i = 0; input_data[i] != NULL; i++) {
res = KSI_DataHash_create(ctx, input_data[i], strlen(input_data[i]), KSI_HASHALG_SHA2_256, &hsh);
CuAssert(tc, "Unable to create data hash.", res == KSI_OK && hsh != NULL);
if (genMeta) {
char clientId[100];
KSI_snprintf(clientId, sizeof(clientId), "Client-%d", i);
res = createMetaData(clientId, &md);
CuAssert(tc, "Unable to create metadata.", res == KSI_OK && md != NULL);
res = KSI_BlockSigner_addLeaf(bs, hsh, 0, md, NULL);
CuAssert(tc, "Unable to add leaf with meta data.", res == KSI_OK);
KSI_MetaData_free(md);
md = NULL;
} else {
res = KSI_BlockSigner_add(bs, hsh);
CuAssert(tc, "Unable to add data hash to the block signer.", res == KSI_OK);
}
KSI_DataHash_free(hsh);
hsh = NULL;
}
}
示例15: rbtree_1
static void rbtree_1(CuTest *tc)
{
/* tree should be empty on start. */
CuAssert(tc, "empty tree?", (rbtree_first((rbtree_t*)tree) == &rbtree_null_node));
CuAssert(tc, "empty tree?", (rbtree_last((rbtree_t*)tree) == &rbtree_null_node));
test_tree_integrity(tc, tree);
}