diff options
author | kinuko@chromium.org <kinuko@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-01-27 10:26:56 +0000 |
---|---|---|
committer | kinuko@chromium.org <kinuko@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-01-27 10:26:56 +0000 |
commit | f83b5b783ac4fd566328772caccb5c3e2d8b8f9a (patch) | |
tree | e098a0aa3aab90d29ab8bacdd8ec4328fa6813c6 /webkit/fileapi/test_file_set.cc | |
parent | 6e3953dd1dd86347917a18afc83f8c7d1792cd25 (diff) | |
download | chromium_src-f83b5b783ac4fd566328772caccb5c3e2d8b8f9a.zip chromium_src-f83b5b783ac4fd566328772caccb5c3e2d8b8f9a.tar.gz chromium_src-f83b5b783ac4fd566328772caccb5c3e2d8b8f9a.tar.bz2 |
Cleanup: factor out common test sets under fileapi/
I wanted to use the same set of files for other testing and wanted to make this cleanup first.
BUG=none
TEST=existing tests
Review URL: https://chromiumcodereview.appspot.com/9200005
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@119432 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/fileapi/test_file_set.cc')
-rw-r--r-- | webkit/fileapi/test_file_set.cc | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/webkit/fileapi/test_file_set.cc b/webkit/fileapi/test_file_set.cc new file mode 100644 index 0000000..badb7fb --- /dev/null +++ b/webkit/fileapi/test_file_set.cc @@ -0,0 +1,69 @@ +// Copyright (c) 2012 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "webkit/fileapi/test_file_set.h" + +#include "base/file_util.h" +#include "base/logging.h" +#include "base/platform_file.h" +#include "testing/gtest/include/gtest/gtest.h" + +namespace fileapi { + +namespace test { + +const TestCaseRecord kRegularTestCases[] = { + {true, FILE_PATH_LITERAL("dir a"), 0}, + {true, FILE_PATH_LITERAL("dir a/dir a"), 0}, + {true, FILE_PATH_LITERAL("dir a/dir d"), 0}, + {true, FILE_PATH_LITERAL("dir a/dir d/dir e"), 0}, + {true, FILE_PATH_LITERAL("dir a/dir d/dir e/dir f"), 0}, + {true, FILE_PATH_LITERAL("dir a/dir d/dir e/dir g"), 0}, + {true, FILE_PATH_LITERAL("dir a/dir d/dir e/dir h"), 0}, + {true, FILE_PATH_LITERAL("dir b"), 0}, + {true, FILE_PATH_LITERAL("dir b/dir a"), 0}, + {true, FILE_PATH_LITERAL("dir c"), 0}, + {false, FILE_PATH_LITERAL("file 0"), 38}, + {false, FILE_PATH_LITERAL("file 2"), 60}, + {false, FILE_PATH_LITERAL("file 3"), 0}, + {false, FILE_PATH_LITERAL("dir a/file 0"), 39}, + {false, FILE_PATH_LITERAL("dir a/dir d/dir e/dir g/file 0"), 40}, + {false, FILE_PATH_LITERAL("dir a/dir d/dir e/dir g/file 1"), 41}, + {false, FILE_PATH_LITERAL("dir a/dir d/dir e/dir g/file 2"), 42}, + {false, FILE_PATH_LITERAL("dir a/dir d/dir e/dir g/file 3"), 50}, +}; + +const size_t kRegularTestCaseSize = arraysize(kRegularTestCases); + +void SetUpOneTestCase(const FilePath& root_path, + const TestCaseRecord& test_case) { + FilePath path = root_path.Append(test_case.path); + if (test_case.is_directory) { + ASSERT_TRUE(file_util::CreateDirectory(path)); + } else { + base::PlatformFileError error_code; + bool created = false; + int file_flags = base::PLATFORM_FILE_CREATE | base::PLATFORM_FILE_WRITE; + base::PlatformFile file_handle = + base::CreatePlatformFile(path, file_flags, &created, &error_code); + EXPECT_TRUE(created); + ASSERT_NE(base::kInvalidPlatformFileValue, file_handle); + ASSERT_EQ(base::PLATFORM_FILE_OK, error_code); + ASSERT_TRUE( + base::TruncatePlatformFile(file_handle, test_case.data_file_size)); + EXPECT_TRUE(base::ClosePlatformFile(file_handle)); + } +} + + +void SetUpRegularTestCases(const FilePath& root_path) { + for (size_t i = 0; i < arraysize(kRegularTestCases); ++i) { + SCOPED_TRACE(testing::Message() << "Creating kRegularTestCases " << i); + SetUpOneTestCase(root_path, kRegularTestCases[i]); + } +} + +} // namespace test + +} // namespace fileapi |