Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(640)

Side by Side Diff: webkit/database/databases_table_unittest.cc

Issue 507014: Adding methods that will be used by the quota management UI.... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 10 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « webkit/database/databases_table.cc ('k') | webkit/database/quota_table.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "app/sql/connection.h" 5 #include "app/sql/connection.h"
6 #include "app/sql/statement.h" 6 #include "app/sql/statement.h"
7 #include "base/scoped_temp_dir.h"
8 #include "base/string_util.h" 7 #include "base/string_util.h"
9 #include "testing/gtest/include/gtest/gtest.h" 8 #include "testing/gtest/include/gtest/gtest.h"
10 #include "webkit/database/databases_table.h" 9 #include "webkit/database/databases_table.h"
11 10
12 namespace webkit_database { 11 namespace {
13 12
14 class TestErrorDelegate : public sql::ErrorDelegate { 13 class TestErrorDelegate : public sql::ErrorDelegate {
15 public: 14 public:
16 virtual ~TestErrorDelegate() { } 15 virtual ~TestErrorDelegate() { }
17 virtual int OnError( 16 virtual int OnError(
18 int error, sql::Connection* connection, sql::Statement* stmt) { 17 int error, sql::Connection* connection, sql::Statement* stmt) {
19 return error; 18 return error;
20 } 19 }
21 }; 20 };
22 21
22 } // namespace
23
24 namespace webkit_database {
25
23 static void CheckDetailsAreEqual(const DatabaseDetails& d1, 26 static void CheckDetailsAreEqual(const DatabaseDetails& d1,
24 const DatabaseDetails& d2) { 27 const DatabaseDetails& d2) {
25 EXPECT_EQ(d1.origin_identifier, d2.origin_identifier); 28 EXPECT_EQ(d1.origin_identifier, d2.origin_identifier);
26 EXPECT_EQ(d1.database_name, d2.database_name); 29 EXPECT_EQ(d1.database_name, d2.database_name);
27 EXPECT_EQ(d1.description, d2.description); 30 EXPECT_EQ(d1.description, d2.description);
28 EXPECT_EQ(d1.estimated_size, d2.estimated_size); 31 EXPECT_EQ(d1.estimated_size, d2.estimated_size);
29 } 32 }
30 33
31 static bool DatabasesTableIsEmpty(sql::Connection* db) { 34 static bool DatabasesTableIsEmpty(sql::Connection* db) {
32 sql::Statement statement(db->GetCachedStatement( 35 sql::Statement statement(db->GetCachedStatement(
33 SQL_FROM_HERE, "SELECT COUNT(*) FROM Databases")); 36 SQL_FROM_HERE, "SELECT COUNT(*) FROM Databases"));
34 return (statement.is_valid() && statement.Step() && !statement.ColumnInt(0)); 37 return (statement.is_valid() && statement.Step() && !statement.ColumnInt(0));
35 } 38 }
36 39
37 TEST(DatabasesTableTest, TestIt) { 40 TEST(DatabasesTableTest, TestIt) {
38 // Initialize the 'Databases' table. 41 // Initialize the 'Databases' table.
39 ScopedTempDir temp_dir;
40 sql::Connection db; 42 sql::Connection db;
41 43
42 // Set an error delegate that will make all operations return false on error. 44 // Set an error delegate that will make all operations return false on error.
43 scoped_refptr<TestErrorDelegate> error_delegate(new TestErrorDelegate()); 45 scoped_refptr<TestErrorDelegate> error_delegate(new TestErrorDelegate());
44 db.set_error_delegate(error_delegate); 46 db.set_error_delegate(error_delegate);
45 47
46 // Initialize the temp dir and the 'Databases' table. 48 // Initialize the temp dir and the 'Databases' table.
47 EXPECT_TRUE(temp_dir.CreateUniqueTempDir()); 49 EXPECT_TRUE(db.OpenInMemory());
48 EXPECT_TRUE(db.Open(temp_dir.path().Append(FILE_PATH_LITERAL("tracker.db"))));
49 DatabasesTable databases_table(&db); 50 DatabasesTable databases_table(&db);
50 EXPECT_TRUE(databases_table.Init()); 51 EXPECT_TRUE(databases_table.Init());
51 52
52 // The 'Databases' table should be empty. 53 // The 'Databases' table should be empty.
53 EXPECT_TRUE(DatabasesTableIsEmpty(&db)); 54 EXPECT_TRUE(DatabasesTableIsEmpty(&db));
54 55
55 // Create the details for a databases. 56 // Create the details for a databases.
56 DatabaseDetails details_in1; 57 DatabaseDetails details_in1;
57 DatabaseDetails details_out1; 58 DatabaseDetails details_out1;
58 details_in1.origin_identifier = ASCIIToUTF16("origin1"); 59 details_in1.origin_identifier = ASCIIToUTF16("origin1");
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after
109 EXPECT_TRUE(details_out_origin3.empty()); 110 EXPECT_TRUE(details_out_origin3.empty());
110 111
111 // There should be only two databases with origin "origin1". 112 // There should be only two databases with origin "origin1".
112 std::vector<DatabaseDetails> details_out_origin1; 113 std::vector<DatabaseDetails> details_out_origin1;
113 EXPECT_TRUE(databases_table.GetAllDatabaseDetailsForOrigin( 114 EXPECT_TRUE(databases_table.GetAllDatabaseDetailsForOrigin(
114 details_in1.origin_identifier, &details_out_origin1)); 115 details_in1.origin_identifier, &details_out_origin1));
115 EXPECT_EQ(size_t(2), details_out_origin1.size()); 116 EXPECT_EQ(size_t(2), details_out_origin1.size());
116 CheckDetailsAreEqual(details_in1, details_out_origin1[0]); 117 CheckDetailsAreEqual(details_in1, details_out_origin1[0]);
117 CheckDetailsAreEqual(details_in2, details_out_origin1[1]); 118 CheckDetailsAreEqual(details_in2, details_out_origin1[1]);
118 119
120 // Get the list of all origins: should be "origin1" and "origin2".
121 std::vector<string16> origins_out;
122 EXPECT_TRUE(databases_table.GetAllOrigins(&origins_out));
123 EXPECT_EQ(size_t(2), origins_out.size());
124 EXPECT_EQ(details_in1.origin_identifier, origins_out[0]);
125 EXPECT_EQ(details_in3.origin_identifier, origins_out[1]);
126
127 // Delete an origin and check that it's no longer in the table.
128 origins_out.clear();
129 EXPECT_TRUE(databases_table.DeleteOrigin(details_in3.origin_identifier));
130 EXPECT_TRUE(databases_table.GetAllOrigins(&origins_out));
131 EXPECT_EQ(size_t(1), origins_out.size());
132 EXPECT_EQ(details_in1.origin_identifier, origins_out[0]);
133
134 // Deleting an origin that doesn't have any record in this table should fail.
135 EXPECT_FALSE(databases_table.DeleteOrigin(ASCIIToUTF16("unknown_origin")));
136
119 // Delete the details for 'db1' and check that they're no longer there. 137 // Delete the details for 'db1' and check that they're no longer there.
120 EXPECT_TRUE(databases_table.DeleteDatabaseDetails( 138 EXPECT_TRUE(databases_table.DeleteDatabaseDetails(
121 details_in1.origin_identifier, details_in1.database_name)); 139 details_in1.origin_identifier, details_in1.database_name));
122 EXPECT_FALSE(databases_table.GetDatabaseDetails( 140 EXPECT_FALSE(databases_table.GetDatabaseDetails(
123 details_in1.origin_identifier, 141 details_in1.origin_identifier,
124 details_in1.database_name, 142 details_in1.database_name,
125 &details_out1)); 143 &details_out1));
126 144
127 // Check that trying to delete a record that doesn't exist fails. 145 // Check that trying to delete a record that doesn't exist fails.
128 EXPECT_FALSE(databases_table.DeleteDatabaseDetails( 146 EXPECT_FALSE(databases_table.DeleteDatabaseDetails(
129 ASCIIToUTF16("unknown_origin"), ASCIIToUTF16("unknown_database"))); 147 ASCIIToUTF16("unknown_origin"), ASCIIToUTF16("unknown_database")));
130 } 148 }
131 149
132 } // namespace webkit_database 150 } // namespace webkit_database
OLDNEW
« no previous file with comments | « webkit/database/databases_table.cc ('k') | webkit/database/quota_table.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698