| 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 |