mirror of
https://github.com/postgres/postgres.git
synced 2025-07-31 22:04:40 +03:00
Clean up thread test program.
This commit is contained in:
@ -6,7 +6,7 @@
|
|||||||
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
|
* Portions Copyright (c) 1996-2003, PostgreSQL Global Development Group
|
||||||
* Portions Copyright (c) 1994, Regents of the University of California
|
* Portions Copyright (c) 1994, Regents of the University of California
|
||||||
*
|
*
|
||||||
* $PostgreSQL: pgsql/src/tools/thread/thread_test.c,v 1.8 2004/03/27 23:02:44 momjian Exp $
|
* $PostgreSQL: pgsql/src/tools/thread/thread_test.c,v 1.9 2004/03/28 02:37:31 momjian Exp $
|
||||||
*
|
*
|
||||||
* This program tests to see if your standard libc functions use
|
* This program tests to see if your standard libc functions use
|
||||||
* pthread_setspecific()/pthread_getspecific() to be thread-safe.
|
* pthread_setspecific()/pthread_getspecific() to be thread-safe.
|
||||||
@ -93,15 +93,13 @@ defines to your template/$port file before compiling this program.\n\n"
|
|||||||
void func_call_1(void) {
|
void func_call_1(void) {
|
||||||
void *p;
|
void *p;
|
||||||
|
|
||||||
if (open("/tmp/thread_test.1", O_RDWR | O_CREAT, 0600) < 0)
|
unlink("/tmp/thread_test.1");
|
||||||
|
/* create, then try to fail on exclusive create open */
|
||||||
|
if (open("/tmp/thread_test.1", O_RDWR | O_CREAT, 0600) < 0 ||
|
||||||
|
open("/tmp/thread_test.1", O_RDWR | O_CREAT | O_EXCL, 0600) >= 0)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Could not create file in /tmp, exiting\n");
|
fprintf(stderr, "Could not create file in /tmp or\n");
|
||||||
exit(1);
|
fprintf(stderr, "could not generate failure for create file in /tmp, exiting\n");
|
||||||
}
|
|
||||||
|
|
||||||
if (open("/tmp/thread_test.1", O_RDWR | O_CREAT | O_EXCL, 0600) >= 0)
|
|
||||||
{
|
|
||||||
fprintf(stderr, "Could not generate failure for create file in /tmp, exiting\n");
|
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
/* wait for other thread to set errno */
|
/* wait for other thread to set errno */
|
||||||
@ -144,6 +142,7 @@ void func_call_2(void) {
|
|||||||
void *p;
|
void *p;
|
||||||
|
|
||||||
unlink("/tmp/thread_test.2");
|
unlink("/tmp/thread_test.2");
|
||||||
|
/* open non-existant file */
|
||||||
if (open("/tmp/thread_test.2", O_RDONLY, 0600) >= 0)
|
if (open("/tmp/thread_test.2", O_RDONLY, 0600) >= 0)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Read-only open succeeded without create, exiting\n");
|
fprintf(stderr, "Read-only open succeeded without create, exiting\n");
|
||||||
@ -159,6 +158,7 @@ void func_call_2(void) {
|
|||||||
unlink("/tmp/thread_test.A");
|
unlink("/tmp/thread_test.A");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
unlink("/tmp/thread_test.2");
|
||||||
|
|
||||||
strerror_p2 = strerror(EINVAL);
|
strerror_p2 = strerror(EINVAL);
|
||||||
/*
|
/*
|
||||||
|
Reference in New Issue
Block a user