Files
openGauss-server/contrib/gtm/test/test_seq4.cpp
2020-06-30 17:38:27 +08:00

268 lines
6.9 KiB
C++

/*
* Copyright (c) 2010-2012 Postgres-XC Development Group
*/
#include <sys/types.h>
#include <unistd.h>
#include "gtm/libpq-fe.h"
#include "gtm/gtm_c.h"
#include "gtm/gtm_client.h"
#include "gtm/register.h"
#include "test_common.h"
pthread_key_t threadinfo_key;
void setUp()
{
connect1();
}
void tearDown()
{
GTMPQfinish(conn);
}
void test_seq4_01()
{
int rc;
GTM_SequenceKeyData seqkey;
GTM_Sequence increment;
GTM_Sequence minval;
GTM_Sequence maxval;
GTM_Sequence startval;
bool cycle;
GTM_Sequence cur;
SETUP();
/*
* open sequence
*/
seqkey.gsk_key = strdup("seq1");
seqkey.gsk_keylen = strlen(seqkey.gsk_key);
seqkey.gsk_type = GTM_SEQ_FULL_NAME;
increment = 1;
minval = 0;
maxval = 10000;
startval = 0;
cycle = true;
rc = open_sequence(conn, &seqkey, increment, minval, maxval, startval, cycle);
_ASSERT(rc >= 0);
_ASSERT(grep_count(LOG_ACTIVE, "Opening sequence seq1") == 1);
_ASSERT(grep_count(LOG_STANDBY, "Opening sequence seq1") == 1);
/*
* get current
*/
cur = get_current(conn, &seqkey);
_ASSERT(cur == 0);
_ASSERT(grep_count(LOG_ACTIVE, "Getting current value 0 for sequence seq1") == 1);
_ASSERT(grep_count(LOG_STANDBY, "Getting current value 0 for sequence seq1") == 1);
cur = get_current(conn, &seqkey);
_ASSERT(cur == 0);
_ASSERT(grep_count(LOG_ACTIVE, "Getting current value 0 for sequence seq1") == 2);
_ASSERT(grep_count(LOG_STANDBY, "Getting current value 0 for sequence seq1") == 2);
/*
* get next
*/
cur = get_next(conn, &seqkey);
_ASSERT(cur == 1);
_ASSERT(grep_count(LOG_ACTIVE, "Getting next value 1 for sequence seq1") == 1);
_ASSERT(grep_count(LOG_STANDBY, "Getting next value 1 for sequence seq1") == 1);
cur = get_next(conn, &seqkey);
_ASSERT(cur == 2);
_ASSERT(grep_count(LOG_ACTIVE, "Getting next value 2 for sequence seq1") == 1);
_ASSERT(grep_count(LOG_STANDBY, "Getting next value 2 for sequence seq1") == 1);
cur = get_next(conn, &seqkey);
_ASSERT(cur == 3);
_ASSERT(grep_count(LOG_ACTIVE, "Getting next value 3 for sequence seq1") == 1);
_ASSERT(grep_count(LOG_STANDBY, "Getting next value 3 for sequence seq1") == 1);
/*
* set value
*/
rc = set_val(conn, &seqkey, 13, true);
_ASSERT(rc >= 0);
_ASSERT(grep_count(LOG_ACTIVE, "Setting new value 13 for sequence seq1") == 1);
_ASSERT(grep_count(LOG_STANDBY, "Setting new value 13 for sequence seq1") == 1);
cur = get_next(conn, &seqkey);
_ASSERT(cur == 14);
_ASSERT(grep_count(LOG_ACTIVE, "Getting next value 14 for sequence seq1") == 1);
_ASSERT(grep_count(LOG_STANDBY, "Getting next value 14 for sequence seq1") == 1);
#ifdef NOT_USED /* FIXME: snaga \
/* \
* FIXME: When `iscalled' is false, set_val() does not affect the sequence value. \
*/
rc = set_val(conn, &seqkey, 1000, false);
#endif
/*
* reset
*/
rc = reset_sequence(conn, &seqkey);
_ASSERT(cur >= 0);
_ASSERT(grep_count(LOG_ACTIVE, "Resetting sequence seq1") == 1);
_ASSERT(grep_count(LOG_STANDBY, "Resetting sequence seq1") == 1);
cur = get_next(conn, &seqkey);
_ASSERT(cur == 1);
_ASSERT(grep_count(LOG_ACTIVE, "Getting next value 1 for sequence seq1") == 2);
_ASSERT(grep_count(LOG_STANDBY, "Getting next value 1 for sequence seq1") == 2);
/*
* close
*/
rc = close_sequence(conn, &seqkey);
_ASSERT(rc >= 0);
_ASSERT(grep_count(LOG_ACTIVE, "Closing sequence seq1") == 1);
_ASSERT(grep_count(LOG_STANDBY, "Closing sequence seq1") == 1);
TEARDOWN();
}
void test_seq4_02()
{
int rc;
GTM_SequenceKeyData seqkey;
GTM_SequenceKeyData newseqkey;
GTM_Sequence increment;
GTM_Sequence minval;
GTM_Sequence maxval;
GTM_Sequence startval;
bool cycle;
SETUP();
/*
* create a sequence
*/
seqkey.gsk_key = strdup("seq1");
seqkey.gsk_keylen = strlen(seqkey.gsk_key);
seqkey.gsk_type = GTM_SEQ_FULL_NAME;
increment = 1;
minval = 0;
maxval = 10000;
startval = 0;
cycle = true;
rc = open_sequence(conn, &seqkey, increment, minval, maxval, startval, cycle);
_ASSERT(rc >= 0);
/* create a new key */
newseqkey.gsk_key = strdup("seqnew");
newseqkey.gsk_keylen = strlen(newseqkey.gsk_key);
newseqkey.gsk_type = GTM_SEQ_FULL_NAME;
/*
* rename key
*/
rc = rename_sequence(conn, &seqkey, &newseqkey);
_ASSERT(rc >= 0);
_ASSERT(grep_count(LOG_ACTIVE, "Renaming sequence seq1 to seqnew") == 1);
_ASSERT(grep_count(LOG_STANDBY, "Renaming sequence seq1 to seqnew") == 1);
rc = close_sequence(conn, &newseqkey);
_ASSERT(rc >= 0);
_ASSERT(grep_count(LOG_ACTIVE, "Closing sequence seqnew") == 1);
_ASSERT(grep_count(LOG_STANDBY, "Closing sequence seqnew") == 1);
TEARDOWN();
}
void test_seq4_03()
{
int rc;
GTM_SequenceKeyData seqkey;
GTM_SequenceKeyData newseqkey;
GTM_Sequence increment;
GTM_Sequence minval;
GTM_Sequence maxval;
GTM_Sequence startval;
bool cycle;
GTM_Sequence cur;
SETUP();
/*
* create a sequence
*/
seqkey.gsk_key = strdup("seq2");
seqkey.gsk_keylen = strlen(seqkey.gsk_key);
seqkey.gsk_type = GTM_SEQ_FULL_NAME;
increment = 1;
minval = 0;
maxval = 10000;
startval = 0;
cycle = true;
rc = open_sequence(conn, &seqkey, increment, minval, maxval, startval, cycle);
_ASSERT(rc >= 0);
{
GTM_Sequence increment;
GTM_Sequence minval;
GTM_Sequence maxval;
GTM_Sequence startval;
bool cycle;
increment = 1;
minval = 100;
maxval = 10000;
startval = 100;
cycle = true;
rc = alter_sequence(conn,
&seqkey,
increment,
minval,
maxval,
startval,
256, /* lastval */
cycle,
true);
_ASSERT(rc >= 0);
_ASSERT(grep_count(LOG_ACTIVE, "Altering sequence key seq2") == 1);
_ASSERT(grep_count(LOG_STANDBY, "Altering sequence key seq2") == 1);
}
cur = get_current(conn, &seqkey);
_ASSERT(cur == 100);
_ASSERT(grep_count(LOG_ACTIVE, "Getting current value 100 for sequence seq2") == 1);
_ASSERT(grep_count(LOG_STANDBY, "Getting current value 100 for sequence seq2") == 1);
cur = get_next(conn, &seqkey);
_ASSERT(cur == 101);
_ASSERT(grep_count(LOG_ACTIVE, "Getting next value 101 for sequence seq2") == 1);
_ASSERT(grep_count(LOG_STANDBY, "Getting next value 101 for sequence seq2") == 1);
TEARDOWN();
}
int main(int argc, char* argv[])
{
system("./stop.sh");
system("./clean.sh");
system("./start.sh");
test_seq4_01();
test_seq4_02(); /* rename */
test_seq4_03(); /* alter */
return 0;
}