OLD | NEW |
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 Loading... |
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 |
OLD | NEW |