aboutsummaryrefslogtreecommitdiff
path: root/src/interfaces/ecpg/test/test_thread.pgc
diff options
context:
space:
mode:
authorBruce Momjian <bruce@momjian.us>2003-08-06 02:19:51 +0000
committerBruce Momjian <bruce@momjian.us>2003-08-06 02:19:51 +0000
commit149f01c4d463744cd2fe504f017422bbb9e5440e (patch)
treea65ab978b60e61fd29941509c96c8ead7cde2b25 /src/interfaces/ecpg/test/test_thread.pgc
parent630684d3a130bb9381e5256b24d248d6a751d59f (diff)
downloadpostgresql-149f01c4d463744cd2fe504f017422bbb9e5440e.tar.gz
postgresql-149f01c4d463744cd2fe504f017422bbb9e5440e.zip
Add ecpg thread testing file.
Diffstat (limited to 'src/interfaces/ecpg/test/test_thread.pgc')
-rw-r--r--src/interfaces/ecpg/test/test_thread.pgc70
1 files changed, 70 insertions, 0 deletions
diff --git a/src/interfaces/ecpg/test/test_thread.pgc b/src/interfaces/ecpg/test/test_thread.pgc
new file mode 100644
index 00000000000..828d66c6a8c
--- /dev/null
+++ b/src/interfaces/ecpg/test/test_thread.pgc
@@ -0,0 +1,70 @@
+/* ---
+ * Thread test program
+ * by Philip Yarra
+ *
+ * To run, create this table in the 'test' database:
+ *
+ * CREATE TABLE foo (
+ * message character(40)
+ * );
+ * ---
+ */
+
+
+#include <pthread.h>
+
+int main(void);
+void ins1(void);
+void ins2(void);
+
+int main(void)
+{
+ pthread_t thread1, thread2;
+ pthread_create(&thread1, NULL, (void *) ins1, NULL);
+ pthread_create(&thread2, NULL, (void *) ins2, NULL);
+ pthread_join(thread1, NULL);
+ pthread_join(thread2, NULL);
+ printf("Program done!\n");
+ return 0;
+}
+
+void ins1(void)
+{
+ int i;
+ EXEC SQL BEGIN DECLARE SECTION;
+ char* cs = "test";
+ char* bar = "one!";
+ EXEC SQL END DECLARE SECTION;
+ EXEC SQL WHENEVER sqlerror sqlprint;
+ EXEC SQL CONNECT TO :cs AS test1;
+ for (i = 0; i < 5; i++)
+ {
+ printf("thread 1 : inserting\n");
+ EXEC SQL AT test1 INSERT INTO foo VALUES(:bar);
+ printf("thread 1 : insert done\n");
+ }
+ EXEC SQL AT test1 COMMIT WORK;
+ EXEC SQL DISCONNECT test1;
+ printf("thread 1 : done!\n");
+}
+
+
+void ins2(void)
+{
+ int i;
+ EXEC SQL BEGIN DECLARE SECTION;
+ char* cs = "test";
+ char* bar = "two!";
+ EXEC SQL END DECLARE SECTION;
+ EXEC SQL WHENEVER sqlerror sqlprint;
+ EXEC SQL CONNECT TO :cs AS test2;
+ for (i = 0; i < 5; i++)
+ {
+ printf("thread 2: inserting\n");
+ EXEC SQL AT test2 INSERT INTO foo VALUES(:bar);
+ printf("thread 2: insert done\n");
+ }
+ EXEC SQL AT test2 COMMIT WORK;
+ EXEC SQL DISCONNECT test2;
+ printf("thread 2: done!\n");
+}