⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 testfile.c

📁 apache的软件linux版本
💻 C
📖 第 1 页 / 共 2 页
字号:
    f = NULL;    rv = apr_file_open(&f, "data/created_file", APR_READ, 0, p);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    nbytes = sizeof buf;    rv = apr_file_read(f, buf, &nbytes);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    CuAssertIntEquals(tc, APR_BUFFERSIZE, nbytes);    rv = apr_file_close(f);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    rv = apr_file_remove("data/created_file", p);    CuAssertIntEquals(tc, APR_SUCCESS, rv);}/* Test that the contents of file FNAME are equal to data EXPECT of * length EXPECTLEN. */static void file_contents_equal(CuTest *tc,                                const char *fname,                                const void *expect,                                apr_size_t expectlen){    void *actual = apr_palloc(p, expectlen);    apr_file_t *f;    apr_status_t rv;    int rc;        rv = apr_file_open(&f, fname, APR_READ|APR_BUFFERED, 0, p);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    rv = apr_file_read_full(f, actual, expectlen, NULL);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    rc = memcmp(expect, actual, expectlen);    CuAssertIntEquals(tc, 0, rc);    rv = apr_file_close(f);    CuAssertIntEquals(tc, APR_SUCCESS, rv);}#define LINE1 "this is a line of text\n"#define LINE2 "this is a second line of text\n"static void test_writev_buffered(CuTest *tc){    apr_status_t rv;    apr_file_t *f;    apr_size_t nbytes;    struct iovec vec[2];    const char *fname = "data/testwritev_buffered.dat";    rv = apr_file_open(&f, fname,                       APR_WRITE | APR_CREATE | APR_TRUNCATE |                       APR_BUFFERED, APR_OS_DEFAULT, p);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    nbytes = strlen(TESTSTR);    rv = apr_file_write(f, TESTSTR, &nbytes);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    vec[0].iov_base = LINE1;    vec[0].iov_len = strlen(LINE1);    vec[1].iov_base = LINE2;    vec[1].iov_len = strlen(LINE2);    rv = apr_file_writev(f, vec, 2, &nbytes);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    rv = apr_file_close(f);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    file_contents_equal(tc, fname, TESTSTR LINE1 LINE2,                        strlen(TESTSTR) + strlen(LINE1) + strlen(LINE2));}static void test_writev_buffered_seek(CuTest *tc){    apr_file_t *f;    apr_status_t rv;    apr_off_t off = 0;    struct iovec vec[3];    apr_size_t nbytes = strlen(TESTSTR);    char *str = apr_pcalloc(p, nbytes+1);    const char *fname = "data/testwritev_buffered.dat";    rv = apr_file_open(&f, fname,                       APR_WRITE | APR_READ | APR_BUFFERED,                       APR_OS_DEFAULT, p);    rv = apr_file_read(f, str, &nbytes);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    CuAssertStrEquals(tc, TESTSTR, str);    rv = apr_file_seek(f, APR_SET, &off);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    vec[0].iov_base = LINE1;    vec[0].iov_len = strlen(LINE1);    vec[1].iov_base = LINE2;    vec[1].iov_len = strlen(LINE2);    vec[2].iov_base = TESTSTR;    vec[2].iov_len = strlen(TESTSTR);    rv = apr_file_writev(f, vec, 3, &nbytes);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    rv = apr_file_close(f);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    file_contents_equal(tc, fname, LINE1 LINE2 TESTSTR,                        strlen(LINE1) + strlen(LINE2) + strlen(TESTSTR));    rv = apr_file_remove(fname, p);    CuAssertIntEquals(tc, APR_SUCCESS, rv);}/* This is a horrible name for this function.  We are testing APR, not how * Apache uses APR.  And, this function tests _way_ too much stuff. */static void test_mod_neg(CuTest *tc){    apr_status_t rv;    apr_file_t *f;    const char *s;    int i;    apr_size_t nbytes;    char buf[8192];    apr_off_t cur;    const char *fname = "data/modneg.dat";    rv = apr_file_open(&f, fname,                        APR_CREATE | APR_WRITE, APR_UREAD | APR_UWRITE, p);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    s = "body56789\n";    nbytes = strlen(s);    rv = apr_file_write(f, s, &nbytes);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    CuAssertIntEquals(tc, strlen(s), nbytes);        for (i = 0; i < 7980; i++) {        s = "0";        nbytes = strlen(s);        rv = apr_file_write(f, s, &nbytes);        CuAssertIntEquals(tc, APR_SUCCESS, rv);        CuAssertIntEquals(tc, strlen(s), nbytes);    }        s = "end456789\n";    nbytes = strlen(s);    rv = apr_file_write(f, s, &nbytes);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    CuAssertIntEquals(tc, strlen(s), nbytes);    for (i = 0; i < 10000; i++) {        s = "1";        nbytes = strlen(s);        rv = apr_file_write(f, s, &nbytes);        CuAssertIntEquals(tc, APR_SUCCESS, rv);        CuAssertIntEquals(tc, strlen(s), nbytes);    }        rv = apr_file_close(f);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    rv = apr_file_open(&f, fname, APR_READ, 0, p);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    rv = apr_file_gets(buf, 11, f);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    CuAssertStrEquals(tc, "body56789\n", buf);    cur = 0;    rv = apr_file_seek(f, APR_CUR, &cur);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    CuAssert(tc, "File Pointer Mismatch, expected 10", cur == 10);    nbytes = sizeof(buf);    rv = apr_file_read(f, buf, &nbytes);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    CuAssertIntEquals(tc, nbytes, sizeof(buf));    cur = -((apr_off_t)nbytes - 7980);    rv = apr_file_seek(f, APR_CUR, &cur);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    CuAssert(tc, "File Pointer Mismatch, expected 7990", cur == 7990);    rv = apr_file_gets(buf, 11, f);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    CuAssertStrEquals(tc, "end456789\n", buf);    rv = apr_file_close(f);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    rv = apr_file_remove(fname, p);    CuAssertIntEquals(tc, APR_SUCCESS, rv);}static void test_truncate(CuTest *tc){    apr_status_t rv;    apr_file_t *f;    const char *fname = "data/testtruncate.dat";    const char *s;    apr_size_t nbytes;    apr_finfo_t finfo;    apr_file_remove(fname, p);    rv = apr_file_open(&f, fname,                       APR_CREATE | APR_WRITE, APR_UREAD | APR_UWRITE, p);    CuAssertIntEquals(tc, APR_SUCCESS, rv);        s = "some data";    nbytes = strlen(s);    rv = apr_file_write(f, s, &nbytes);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    CuAssertIntEquals(tc, strlen(s), nbytes);    rv = apr_file_close(f);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    rv = apr_file_open(&f, fname,                       APR_TRUNCATE | APR_WRITE, APR_UREAD | APR_UWRITE, p);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    rv = apr_file_close(f);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    rv = apr_stat(&finfo, fname, APR_FINFO_SIZE, p);    CuAssertIntEquals(tc, APR_SUCCESS, rv);    CuAssert(tc, "File size mismatch, expected 0 (empty)", finfo.size == 0);    rv = apr_file_remove(fname, p);    CuAssertIntEquals(tc, APR_SUCCESS, rv);}static void test_fail_write_flush(CuTest *tc){    apr_file_t *f;    const char *fname = "data/testflush.dat";    apr_status_t rv;    char buf[APR_BUFFERSIZE];    int n;    apr_file_remove(fname, p);    apr_assert_success(tc, "open test file",                       apr_file_open(&f, fname,                                     APR_CREATE|APR_READ|APR_BUFFERED,                                     APR_UREAD|APR_UWRITE, p));    memset(buf, 'A', sizeof buf);    /* Try three writes.  One of these should fail when it exceeds the     * internal buffer and actually tries to write to the file, which     * was opened read-only and hence should be unwritable. */    for (n = 0, rv = APR_SUCCESS; n < 4 && rv == APR_SUCCESS; n++) {        apr_size_t bytes = sizeof buf;        rv = apr_file_write(f, buf, &bytes);    }    CuAssert(tc, "failed to write to read-only buffered fd",             rv != APR_SUCCESS);    apr_file_close(f);    apr_file_remove(fname, p);}static void test_fail_read_flush(CuTest *tc){    apr_file_t *f;    const char *fname = "data/testflush.dat";    apr_status_t rv;    char buf[2];    apr_file_remove(fname, p);    apr_assert_success(tc, "open test file",                       apr_file_open(&f, fname,                                     APR_CREATE|APR_READ|APR_BUFFERED,                                     APR_UREAD|APR_UWRITE, p));    /* this write should be buffered. */    apr_assert_success(tc, "buffered write should succeed",                       apr_file_puts("hello", f));    /* Now, trying a read should fail since the write must be flushed,     * and should fail with something other than EOF since the file is     * opened read-only. */    rv = apr_file_read_full(f, buf, 2, NULL);    CuAssert(tc, "read should flush buffered write and fail",             rv != APR_SUCCESS && rv != APR_EOF);    /* Likewise for gets */    rv = apr_file_gets(buf, 2, f);    CuAssert(tc, "gets should flush buffered write and fail",             rv != APR_SUCCESS && rv != APR_EOF);    apr_file_close(f);    apr_file_remove(fname, p);}static void test_xthread(CuTest *tc){    apr_file_t *f;    const char *fname = "data/testxthread.dat";    apr_status_t rv;    apr_int32_t flags = APR_CREATE|APR_READ|APR_WRITE|APR_APPEND|APR_XTHREAD;    char buf[128] = { 0 };    /* Test for bug 38438, opening file with append + xthread and seeking to        the end of the file resulted in writes going to the beginning not the       end. */    apr_file_remove(fname, p);    rv = apr_file_open(&f, fname, flags, APR_UREAD|APR_UWRITE, p);    CuAssert(tc, "open test file", rv == APR_SUCCESS);    rv = apr_file_puts("hello", f);    CuAssert(tc, "write should succeed", rv == APR_SUCCESS);    apr_file_close(f);        rv = apr_file_open(&f, fname, flags, APR_UREAD|APR_UWRITE, p);    CuAssert(tc, "open test file", rv == APR_SUCCESS);    /* Seek to the end. */    {        apr_off_t offset = 0;        rv = apr_file_seek(f, APR_END, &offset);    }    rv = apr_file_puts("world", f);    CuAssert(tc, "more writes should succeed", rv == APR_SUCCESS);    /* Back to the beginning. */    {        apr_off_t offset = 0;                rv = apr_file_seek(f, APR_SET, &offset);    }        apr_file_read_full(f, buf, sizeof(buf), NULL);    CuAssertStrEquals(tc, "helloworld", buf);    apr_file_close(f);}CuSuite *testfile(void){    CuSuite *suite = CuSuiteNew("File I/O");    SUITE_ADD_TEST(suite, test_open_noreadwrite);    SUITE_ADD_TEST(suite, test_open_excl);    SUITE_ADD_TEST(suite, test_open_read);    SUITE_ADD_TEST(suite, test_open_readwrite);    SUITE_ADD_TEST(suite, test_read);     SUITE_ADD_TEST(suite, test_seek);    SUITE_ADD_TEST(suite, test_filename);    SUITE_ADD_TEST(suite, test_fileclose);    SUITE_ADD_TEST(suite, test_file_remove);    SUITE_ADD_TEST(suite, test_open_write);    SUITE_ADD_TEST(suite, test_open_writecreate);    SUITE_ADD_TEST(suite, test_write);    SUITE_ADD_TEST(suite, test_userdata_set);    SUITE_ADD_TEST(suite, test_userdata_get);    SUITE_ADD_TEST(suite, test_userdata_getnokey);    SUITE_ADD_TEST(suite, test_getc);    SUITE_ADD_TEST(suite, test_ungetc);    SUITE_ADD_TEST(suite, test_gets);    SUITE_ADD_TEST(suite, test_bigread);    SUITE_ADD_TEST(suite, test_writev_buffered);    SUITE_ADD_TEST(suite, test_writev_buffered_seek);    SUITE_ADD_TEST(suite, test_mod_neg);    SUITE_ADD_TEST(suite, test_truncate);    SUITE_ADD_TEST(suite, test_fail_write_flush);    SUITE_ADD_TEST(suite, test_fail_read_flush);    SUITE_ADD_TEST(suite, test_xthread);    return suite;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -