Commit 8995440e authored by Bruce Momjian's avatar Bruce Momjian

In test_fsync, adjust test headings to match wal_sync_method values;

add more test cases for open_sync of different sizes.
parent 1b393f4e
...@@ -47,6 +47,7 @@ void test_open(void); ...@@ -47,6 +47,7 @@ void test_open(void);
void test_non_sync(void); void test_non_sync(void);
void test_sync(int writes_per_op); void test_sync(int writes_per_op);
void test_open_syncs(void); void test_open_syncs(void);
void test_open_sync(const char *msg, int writes_size);
void test_file_descriptor_sync(void); void test_file_descriptor_sync(void);
void print_elapse(struct timeval start_t, struct timeval stop_t); void print_elapse(struct timeval start_t, struct timeval stop_t);
void die(char *str); void die(char *str);
...@@ -61,8 +62,6 @@ main(int argc, char *argv[]) ...@@ -61,8 +62,6 @@ main(int argc, char *argv[])
test_open(); test_open();
test_non_sync();
/* Test using 1 8k write */ /* Test using 1 8k write */
test_sync(1); test_sync(1);
...@@ -73,6 +72,8 @@ main(int argc, char *argv[]) ...@@ -73,6 +72,8 @@ main(int argc, char *argv[])
test_file_descriptor_sync(); test_file_descriptor_sync();
test_non_sync();
unlink(filename); unlink(filename);
return 0; return 0;
...@@ -105,7 +106,7 @@ handle_args(int argc, char *argv[]) ...@@ -105,7 +106,7 @@ handle_args(int argc, char *argv[])
} }
while ((option = getopt_long(argc, argv, "f:o:", while ((option = getopt_long(argc, argv, "f:o:",
long_options, &optindex)) != -1) long_options, &optindex)) != -1)
{ {
switch (option) switch (option)
{ {
...@@ -126,7 +127,7 @@ handle_args(int argc, char *argv[]) ...@@ -126,7 +127,7 @@ handle_args(int argc, char *argv[])
} }
} }
printf("%d operations per test\n\n", ops_per_test); printf("%d operations per test\n", ops_per_test);
} }
void void
...@@ -161,31 +162,6 @@ test_open(void) ...@@ -161,31 +162,6 @@ test_open(void)
close(tmpfile); close(tmpfile);
} }
void
test_non_sync(void)
{
int tmpfile, ops;
/*
* Test a simple write without fsync
*/
printf("Simple non-sync'ed write:\n");
printf(LABEL_FORMAT, "8k write");
fflush(stdout);
gettimeofday(&start_t, NULL);
for (ops = 0; ops < ops_per_test; ops++)
{
if ((tmpfile = open(filename, O_RDWR, 0)) == -1)
die("Cannot open output file.");
if (write(tmpfile, buf, WRITE_SIZE) != WRITE_SIZE)
die("write failed");
close(tmpfile);
}
gettimeofday(&stop_t, NULL);
print_elapse(start_t, stop_t);
}
void void
test_sync(int writes_per_op) test_sync(int writes_per_op)
{ {
...@@ -193,9 +169,9 @@ test_sync(int writes_per_op) ...@@ -193,9 +169,9 @@ test_sync(int writes_per_op)
bool fs_warning = false; bool fs_warning = false;
if (writes_per_op == 1) if (writes_per_op == 1)
printf("\nCompare file sync methods using one write:\n"); printf("\nCompare file sync methods using one 8k write:\n");
else else
printf("\nCompare file sync methods using two writes:\n"); printf("\nCompare file sync methods using two 8k writes:\n");
printf("(in wal_sync_method preference order, except fdatasync\n"); printf("(in wal_sync_method preference order, except fdatasync\n");
printf("is Linux's default)\n"); printf("is Linux's default)\n");
...@@ -203,16 +179,9 @@ test_sync(int writes_per_op) ...@@ -203,16 +179,9 @@ test_sync(int writes_per_op)
* Test open_datasync if available * Test open_datasync if available
*/ */
#ifdef OPEN_DATASYNC_FLAG #ifdef OPEN_DATASYNC_FLAG
if (writes_per_op == 1) printf(LABEL_FORMAT, "open_datasync"
printf(LABEL_FORMAT, "open_datasync 8k write"
#if PG_O_DIRECT != 0
"*"
#endif
);
else
printf(LABEL_FORMAT, "2 open_datasync 8k writes"
#if PG_O_DIRECT != 0 #if PG_O_DIRECT != 0
"*" " (non-direct I/O)*"
#endif #endif
); );
fflush(stdout); fflush(stdout);
...@@ -243,10 +212,7 @@ test_sync(int writes_per_op) ...@@ -243,10 +212,7 @@ test_sync(int writes_per_op)
} }
else else
{ {
if (writes_per_op == 1) printf(LABEL_FORMAT, "open_datasync (direct I/O)");
printf(LABEL_FORMAT, "open_datasync 8k direct I/O write");
else
printf(LABEL_FORMAT, "2 open_datasync 8k direct I/O writes");
fflush(stdout); fflush(stdout);
gettimeofday(&start_t, NULL); gettimeofday(&start_t, NULL);
...@@ -262,8 +228,6 @@ test_sync(int writes_per_op) ...@@ -262,8 +228,6 @@ test_sync(int writes_per_op)
close(tmpfile); close(tmpfile);
print_elapse(start_t, stop_t); print_elapse(start_t, stop_t);
} }
#else
printf(NA_FORMAT, "o_direct", "n/a\n");
#endif #endif
#else #else
...@@ -274,10 +238,7 @@ test_sync(int writes_per_op) ...@@ -274,10 +238,7 @@ test_sync(int writes_per_op)
* Test fdatasync if available * Test fdatasync if available
*/ */
#ifdef HAVE_FDATASYNC #ifdef HAVE_FDATASYNC
if (writes_per_op == 1) printf(LABEL_FORMAT, "fdatasync");
printf(LABEL_FORMAT, "8k write, fdatasync");
else
printf(LABEL_FORMAT, "8k write, 8k write, fdatasync");
fflush(stdout); fflush(stdout);
if ((tmpfile = open(filename, O_RDWR, 0)) == -1) if ((tmpfile = open(filename, O_RDWR, 0)) == -1)
...@@ -302,10 +263,7 @@ test_sync(int writes_per_op) ...@@ -302,10 +263,7 @@ test_sync(int writes_per_op)
/* /*
* Test fsync * Test fsync
*/ */
if (writes_per_op == 1) printf(LABEL_FORMAT, "fsync");
printf(LABEL_FORMAT, "8k write, fsync");
else
printf(LABEL_FORMAT, "8k write, 8k write, fsync");
fflush(stdout); fflush(stdout);
if ((tmpfile = open(filename, O_RDWR, 0)) == -1) if ((tmpfile = open(filename, O_RDWR, 0)) == -1)
...@@ -329,10 +287,7 @@ test_sync(int writes_per_op) ...@@ -329,10 +287,7 @@ test_sync(int writes_per_op)
* If fsync_writethrough is available, test as well * If fsync_writethrough is available, test as well
*/ */
#ifdef HAVE_FSYNC_WRITETHROUGH #ifdef HAVE_FSYNC_WRITETHROUGH
if (writes_per_op == 1) printf(LABEL_FORMAT, "fsync_writethrough");
printf(LABEL_FORMAT, "8k write, fsync_writethrough");
else
printf(LABEL_FORMAT, "8k write, 8k write, fsync_writethrough");
fflush(stdout); fflush(stdout);
if ((tmpfile = open(filename, O_RDWR, 0)) == -1) if ((tmpfile = open(filename, O_RDWR, 0)) == -1)
...@@ -359,16 +314,9 @@ test_sync(int writes_per_op) ...@@ -359,16 +314,9 @@ test_sync(int writes_per_op)
* Test open_sync if available * Test open_sync if available
*/ */
#ifdef OPEN_SYNC_FLAG #ifdef OPEN_SYNC_FLAG
if (writes_per_op == 1) printf(LABEL_FORMAT, "open_sync"
printf(LABEL_FORMAT, "open_sync 8k write"
#if PG_O_DIRECT != 0
"*"
#endif
);
else
printf(LABEL_FORMAT, "2 open_sync 8k writes"
#if PG_O_DIRECT != 0 #if PG_O_DIRECT != 0
"*" " (non-direct I/O)*"
#endif #endif
); );
fflush(stdout); fflush(stdout);
...@@ -399,10 +347,7 @@ test_sync(int writes_per_op) ...@@ -399,10 +347,7 @@ test_sync(int writes_per_op)
} }
else else
{ {
if (writes_per_op == 1) printf(LABEL_FORMAT, "open_sync (direct I/O)");
printf(LABEL_FORMAT, "open_sync 8k direct I/O write");
else
printf(LABEL_FORMAT, "2 open_sync 8k direct I/O writes");
fflush(stdout); fflush(stdout);
gettimeofday(&start_t, NULL); gettimeofday(&start_t, NULL);
...@@ -418,8 +363,6 @@ test_sync(int writes_per_op) ...@@ -418,8 +363,6 @@ test_sync(int writes_per_op)
close(tmpfile); close(tmpfile);
print_elapse(start_t, stop_t); print_elapse(start_t, stop_t);
} }
#else
printf(NA_FORMAT, "o_direct", "n/a\n");
#endif #endif
#else #else
...@@ -428,7 +371,7 @@ test_sync(int writes_per_op) ...@@ -428,7 +371,7 @@ test_sync(int writes_per_op)
#if defined(OPEN_DATASYNC_FLAG) || defined(OPEN_SYNC_FLAG) #if defined(OPEN_DATASYNC_FLAG) || defined(OPEN_SYNC_FLAG)
if (PG_O_DIRECT != 0) if (PG_O_DIRECT != 0)
printf("* This non-direct I/O option is not used by Postgres.\n"); printf("* This non-direct I/O mode is not used by Postgres.\n");
#endif #endif
if (fs_warning) if (fs_warning)
...@@ -441,14 +384,22 @@ test_sync(int writes_per_op) ...@@ -441,14 +384,22 @@ test_sync(int writes_per_op)
void void
test_open_syncs(void) test_open_syncs(void)
{ {
int tmpfile, ops; printf("\nCompare open_sync with different write sizes:\n");
printf("(This is designed to compare the cost of writing 16k\n");
printf("in different write open_sync sizes.)\n");
test_open_sync(" 1 16k open_sync write", 16);
test_open_sync(" 2 8k open_sync writes", 8);
test_open_sync(" 4 4k open_sync writes", 4);
test_open_sync(" 8 2k open_sync writes", 2);
test_open_sync("16 1k open_sync writes", 1);
}
/*
* Compare 1 to 2 writes void
*/ test_open_sync(const char *msg, int writes_size)
printf("\nCompare open_sync with different sizes:\n"); {
printf("(This is designed to compare the cost of one large\n"); int tmpfile, ops, writes;
printf("sync'ed write and two smaller sync'ed writes.)\n");
/* /*
* Test open_sync with different size files * Test open_sync with different size files
...@@ -458,14 +409,15 @@ test_open_syncs(void) ...@@ -458,14 +409,15 @@ test_open_syncs(void)
printf(NA_FORMAT, "o_direct", "n/a**\n"); printf(NA_FORMAT, "o_direct", "n/a**\n");
else else
{ {
printf(LABEL_FORMAT, "open_sync 16k write"); printf(LABEL_FORMAT, msg);
fflush(stdout); fflush(stdout);
gettimeofday(&start_t, NULL); gettimeofday(&start_t, NULL);
for (ops = 0; ops < ops_per_test; ops++) for (ops = 0; ops < ops_per_test; ops++)
{ {
if (write(tmpfile, buf, WRITE_SIZE * 2) != WRITE_SIZE * 2) for (writes = 0; writes < 16 / writes_size; writes++)
die("write failed"); if (write(tmpfile, buf, writes_size) != writes_size)
die("write failed");
if (lseek(tmpfile, 0, SEEK_SET) == -1) if (lseek(tmpfile, 0, SEEK_SET) == -1)
die("seek failed"); die("seek failed");
} }
...@@ -474,27 +426,6 @@ test_open_syncs(void) ...@@ -474,27 +426,6 @@ test_open_syncs(void)
print_elapse(start_t, stop_t); print_elapse(start_t, stop_t);
} }
if ((tmpfile = open(filename, O_RDWR | OPEN_SYNC_FLAG | PG_O_DIRECT, 0)) == -1)
printf(NA_FORMAT, "o_direct", "n/a**\n");
else
{
printf(LABEL_FORMAT, "2 open_sync 8k writes");
fflush(stdout);
gettimeofday(&start_t, NULL);
for (ops = 0; ops < ops_per_test; ops++)
{
if (write(tmpfile, buf, WRITE_SIZE) != WRITE_SIZE)
die("write failed");
if (write(tmpfile, buf, WRITE_SIZE) != WRITE_SIZE)
die("write failed");
if (lseek(tmpfile, 0, SEEK_SET) == -1)
die("seek failed");
}
gettimeofday(&stop_t, NULL);
close(tmpfile);
print_elapse(start_t, stop_t);
}
#else #else
printf(NA_FORMAT, "open_sync", "n/a\n"); printf(NA_FORMAT, "open_sync", "n/a\n");
#endif #endif
...@@ -520,7 +451,7 @@ test_file_descriptor_sync(void) ...@@ -520,7 +451,7 @@ test_file_descriptor_sync(void)
* first write, fsync and close, which is the * first write, fsync and close, which is the
* normal behavior without multiple descriptors * normal behavior without multiple descriptors
*/ */
printf(LABEL_FORMAT, "8k write, fsync, close"); printf(LABEL_FORMAT, "write, fsync, close");
fflush(stdout); fflush(stdout);
gettimeofday(&start_t, NULL); gettimeofday(&start_t, NULL);
...@@ -549,7 +480,7 @@ test_file_descriptor_sync(void) ...@@ -549,7 +480,7 @@ test_file_descriptor_sync(void)
* This simulates processes fsyncing each other's * This simulates processes fsyncing each other's
* writes. * writes.
*/ */
printf(LABEL_FORMAT, "8k write, close, fsync"); printf(LABEL_FORMAT, "write, close, fsync");
fflush(stdout); fflush(stdout);
gettimeofday(&start_t, NULL); gettimeofday(&start_t, NULL);
...@@ -572,6 +503,31 @@ test_file_descriptor_sync(void) ...@@ -572,6 +503,31 @@ test_file_descriptor_sync(void)
} }
void
test_non_sync(void)
{
int tmpfile, ops;
/*
* Test a simple write without fsync
*/
printf("\nNon-sync'ed 8k writes:\n");
printf(LABEL_FORMAT, "write");
fflush(stdout);
gettimeofday(&start_t, NULL);
for (ops = 0; ops < ops_per_test; ops++)
{
if ((tmpfile = open(filename, O_RDWR, 0)) == -1)
die("Cannot open output file.");
if (write(tmpfile, buf, WRITE_SIZE) != WRITE_SIZE)
die("write failed");
close(tmpfile);
}
gettimeofday(&stop_t, NULL);
print_elapse(start_t, stop_t);
}
/* /*
* print out the writes per second for tests * print out the writes per second for tests
*/ */
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment