Line data Source code
1 : /*
2 : * Purpose: Test we can send another query after beginning transaction
3 : * Some server some additional tokens which can prevent second query to work
4 : * correctly.
5 : */
6 :
7 : #include "common.h"
8 :
9 10 : TEST_MAIN()
10 : {
11 : LOGINREC *login;
12 : DBPROCESS *dbproc;
13 : int i;
14 10 : DBINT testint = -1;
15 :
16 10 : read_login_info(argc, argv);
17 :
18 10 : printf("Starting %s\n", argv[0]);
19 :
20 10 : dbinit();
21 :
22 10 : dberrhandle(syb_err_handler);
23 10 : dbmsghandle(syb_msg_handler);
24 :
25 10 : printf("About to logon\n");
26 :
27 10 : login = dblogin();
28 10 : DBSETLPWD(login, PASSWORD);
29 10 : DBSETLUSER(login, USER);
30 10 : DBSETLAPP(login, "pending");
31 :
32 10 : printf("About to open\n");
33 :
34 10 : dbproc = dbopen(login, SERVER);
35 10 : if (strlen(DATABASE))
36 10 : dbuse(dbproc, DATABASE);
37 10 : dbloginfree(login);
38 :
39 :
40 : /* first query, start transactions */
41 10 : sql_cmd(dbproc);
42 10 : dbsqlexec(dbproc);
43 :
44 : /* second query, select */
45 10 : printf("second select\n");
46 :
47 10 : if (SUCCEED != sql_cmd(dbproc) || SUCCEED != dbsqlexec(dbproc)) {
48 0 : fprintf(stderr, "%s:%d: dbcmd failed\n", __FILE__, __LINE__);
49 0 : exit(1);
50 : }
51 :
52 10 : if (dbresults(dbproc) != SUCCEED) {
53 0 : fprintf(stderr, "Was expecting a result set.");
54 0 : exit(1);
55 : }
56 :
57 10 : for (i = 1; i <= dbnumcols(dbproc); i++)
58 10 : printf("col %d is %s\n", i, dbcolname(dbproc, i));
59 :
60 10 : dbbind(dbproc, 1, INTBIND, 0, (BYTE *) & testint);
61 :
62 10 : if (REG_ROW != dbnextrow(dbproc)) {
63 0 : fprintf(stderr, "Failed. Expected a row\n");
64 0 : exit(1);
65 : }
66 10 : if (testint != 634) {
67 0 : fprintf(stderr, "Failed. Expected i to be %d, was %d\n", i, (int) testint);
68 0 : exit(1);
69 : }
70 10 : if (dbnextrow(dbproc) != NO_MORE_ROWS) {
71 0 : fprintf(stderr, "No other rows expected\n");
72 : }
73 :
74 : /* third query, commit */
75 10 : if (SUCCEED != sql_cmd(dbproc)) {
76 0 : fprintf(stderr, "%s:%d: dbcmd failed\n", __FILE__, __LINE__);
77 0 : exit(1);
78 : }
79 :
80 10 : while (dbresults(dbproc) != NO_MORE_RESULTS)
81 0 : continue;
82 :
83 10 : dbexit();
84 :
85 10 : printf("ok\n");
86 10 : return 0;
87 : }
|