Chromium Code Reviews| Index: chrome/browser/extensions/api/identity/identity_mint_queue_unittest.cc |
| diff --git a/chrome/browser/extensions/api/identity/identity_mint_queue_unittest.cc b/chrome/browser/extensions/api/identity/identity_mint_queue_unittest.cc |
| index dc2128e0d36510297a49c0ea322fba2baa90d13e..96cdd435bc96d28e249099477ad53963e56d1550 100644 |
| --- a/chrome/browser/extensions/api/identity/identity_mint_queue_unittest.cc |
| +++ b/chrome/browser/extensions/api/identity/identity_mint_queue_unittest.cc |
| @@ -6,9 +6,11 @@ |
| #include <vector> |
| +#include "base/memory/scoped_ptr.h" |
| #include "testing/gmock/include/gmock/gmock.h" |
| #include "testing/gtest/include/gtest/gtest.h" |
| +using extensions::ExtensionTokenKey; |
| using extensions::IdentityMintRequestQueue; |
| namespace { |
| @@ -18,168 +20,95 @@ class MockRequest : public extensions::IdentityMintRequestQueue::Request { |
| MOCK_METHOD1(StartMintToken, void(IdentityMintRequestQueue::MintType)); |
| }; |
| +scoped_ptr<ExtensionTokenKey> ExtensionIdToKey( |
| + const std::string& extension_id) { |
| + return scoped_ptr<ExtensionTokenKey>(new ExtensionTokenKey( |
| + extension_id, "user_id", std::set<std::string>())); |
| +} |
| + |
| } // namespace |
| TEST(IdentityMintQueueTest, SerialRequests) { |
| IdentityMintRequestQueue::MintType type = |
| IdentityMintRequestQueue::MINT_TYPE_NONINTERACTIVE; |
| IdentityMintRequestQueue queue; |
| - std::string extension_id("ext_id"); |
| + scoped_ptr<ExtensionTokenKey> key(ExtensionIdToKey("ext_id")); |
| MockRequest request1; |
| MockRequest request2; |
| EXPECT_CALL(request1, StartMintToken(type)).Times(1); |
| - queue.RequestStart(type, extension_id, std::set<std::string>(), &request1); |
| - queue.RequestComplete(type, extension_id, std::set<std::string>(), &request1); |
| + queue.RequestStart(type, *key, &request1); |
| + queue.RequestComplete(type, *key, &request1); |
| EXPECT_CALL(request2, StartMintToken(type)).Times(1); |
| - queue.RequestStart(type, extension_id, std::set<std::string>(), &request2); |
| - queue.RequestComplete(type, extension_id, std::set<std::string>(), &request2); |
| + queue.RequestStart(type, *key, &request2); |
| + queue.RequestComplete(type, *key, &request2); |
| } |
| TEST(IdentityMintQueueTest, InteractiveType) { |
| IdentityMintRequestQueue::MintType type = |
| IdentityMintRequestQueue::MINT_TYPE_INTERACTIVE; |
| IdentityMintRequestQueue queue; |
| - std::string extension_id("ext_id"); |
| + scoped_ptr<ExtensionTokenKey> key(ExtensionIdToKey("ext_id")); |
| MockRequest request1; |
| EXPECT_CALL(request1, StartMintToken(type)).Times(1); |
| - queue.RequestStart(type, extension_id, std::set<std::string>(), &request1); |
| - queue.RequestComplete(type, extension_id, std::set<std::string>(), &request1); |
| + queue.RequestStart(type, *key, &request1); |
| + queue.RequestComplete(type, *key, &request1); |
| } |
| TEST(IdentityMintQueueTest, ParallelRequests) { |
| IdentityMintRequestQueue::MintType type = |
| IdentityMintRequestQueue::MINT_TYPE_NONINTERACTIVE; |
| IdentityMintRequestQueue queue; |
| - std::string extension_id("ext_id"); |
| + scoped_ptr<ExtensionTokenKey> key(ExtensionIdToKey("ext_id")); |
| MockRequest request1; |
| MockRequest request2; |
| MockRequest request3; |
| EXPECT_CALL(request1, StartMintToken(type)).Times(1); |
| - queue.RequestStart(type, extension_id, std::set<std::string>(), &request1); |
| - queue.RequestStart(type, extension_id, std::set<std::string>(), &request2); |
| - queue.RequestStart(type, extension_id, std::set<std::string>(), &request3); |
| + queue.RequestStart(type, *key, &request1); |
| + queue.RequestStart(type, *key, &request2); |
| + queue.RequestStart(type, *key, &request3); |
| EXPECT_CALL(request2, StartMintToken(type)).Times(1); |
| - queue.RequestComplete(type, extension_id, std::set<std::string>(), &request1); |
| + queue.RequestComplete(type, *key, &request1); |
| EXPECT_CALL(request3, StartMintToken(type)).Times(1); |
| - queue.RequestComplete(type, extension_id, std::set<std::string>(), &request2); |
| - |
| - queue.RequestComplete(type, extension_id, std::set<std::string>(), &request3); |
| -} |
| - |
| -TEST(IdentityMintQueueTest, ParallelRequestsFromTwoExtensions) { |
| - IdentityMintRequestQueue::MintType type = |
| - IdentityMintRequestQueue::MINT_TYPE_NONINTERACTIVE; |
| - IdentityMintRequestQueue queue; |
| - std::string extension_id1("ext_id_1"); |
| - std::string extension_id2("ext_id_2"); |
| - MockRequest request1; |
| - MockRequest request2; |
| - |
| - EXPECT_CALL(request1, StartMintToken(type)).Times(1); |
| - EXPECT_CALL(request2, StartMintToken(type)).Times(1); |
| - queue.RequestStart(type, extension_id1, std::set<std::string>(), &request1); |
| - queue.RequestStart(type, extension_id2, std::set<std::string>(), &request2); |
| + queue.RequestComplete(type, *key, &request2); |
| - queue.RequestComplete(type, extension_id1, |
| - std::set<std::string>(), &request1); |
| - queue.RequestComplete(type, extension_id2, |
| - std::set<std::string>(), &request2); |
| + queue.RequestComplete(type, *key, &request3); |
| } |
| -TEST(IdentityMintQueueTest, ParallelRequestsForDifferentScopes) { |
|
fgorski
2013/12/02 20:54:39
Is that one no longer relevant?
Michael Courage
2013/12/02 21:53:06
Yes, it was already a little bit redundant, since
|
| +TEST(IdentityMintQueueTest, ParallelRequestsFromTwoKeys) { |
| IdentityMintRequestQueue::MintType type = |
| IdentityMintRequestQueue::MINT_TYPE_NONINTERACTIVE; |
| IdentityMintRequestQueue queue; |
| - std::string extension_id("ext_id"); |
| + scoped_ptr<ExtensionTokenKey> key1(ExtensionIdToKey("ext_id_1")); |
| + scoped_ptr<ExtensionTokenKey> key2(ExtensionIdToKey("ext_id_2")); |
| MockRequest request1; |
| MockRequest request2; |
| - std::set<std::string> scopes1; |
| - std::set<std::string> scopes2; |
| - |
| - scopes1.insert("a"); |
| - scopes1.insert("b"); |
| - scopes2.insert("a"); |
| EXPECT_CALL(request1, StartMintToken(type)).Times(1); |
| EXPECT_CALL(request2, StartMintToken(type)).Times(1); |
| - queue.RequestStart(type, extension_id, scopes1, &request1); |
| - queue.RequestStart(type, extension_id, scopes2, &request2); |
| - |
| - queue.RequestComplete(type, extension_id, scopes1, &request1); |
| - queue.RequestComplete(type, extension_id, scopes2, &request2); |
| -} |
| + queue.RequestStart(type, *key1, &request1); |
| + queue.RequestStart(type, *key2, &request2); |
| -TEST(IdentityMintQueueTest, KeyComparisons) { |
| - std::string extension_id1("ext_id_1"); |
| - std::string extension_id2("ext_id_2"); |
| - std::set<std::string> scopes1; |
| - std::set<std::string> scopes2; |
| - std::set<std::string> scopes3; |
| - |
| - scopes1.insert("a"); |
| - scopes1.insert("b"); |
| - scopes2.insert("a"); |
| - |
| - std::vector<std::string> ids; |
| - ids.push_back(extension_id1); |
| - ids.push_back(extension_id2); |
| - |
| - std::vector<std::set<std::string> > scopesets; |
| - scopesets.push_back(scopes1); |
| - scopesets.push_back(scopes2); |
| - scopesets.push_back(scopes3); |
| - |
| - std::vector<IdentityMintRequestQueue::RequestKey> keys; |
| - typedef std::vector< |
| - IdentityMintRequestQueue::RequestKey>::const_iterator |
| - RequestKeyIterator; |
| - |
| - std::vector<std::string>::const_iterator id_it; |
| - std::vector<std::set<std::string> >::const_iterator scope_it; |
| - |
| - for (id_it = ids.begin(); id_it != ids.end(); ++id_it) { |
| - for (scope_it = scopesets.begin(); scope_it != scopesets.end(); |
| - ++scope_it) { |
| - keys.push_back(IdentityMintRequestQueue::RequestKey( |
| - IdentityMintRequestQueue::MINT_TYPE_NONINTERACTIVE, *id_it, |
| - *scope_it)); |
| - keys.push_back(IdentityMintRequestQueue::RequestKey( |
| - IdentityMintRequestQueue::MINT_TYPE_INTERACTIVE, *id_it, *scope_it)); |
| - } |
| - } |
| - |
| - // keys should not be less than themselves |
| - for (RequestKeyIterator it = keys.begin(); it != keys.end(); ++it) { |
| - EXPECT_FALSE(*it < *it); |
| - } |
| - |
| - // keys should not equal different keys |
| - for (RequestKeyIterator it1 = keys.begin(); it1 != keys.end(); ++it1) { |
| - RequestKeyIterator it2 = it1; |
| - for (++it2; it2 != keys.end(); ++it2) { |
| - EXPECT_TRUE(*it1 < *it2 || *it2 < *it1); |
| - EXPECT_FALSE(*it1 < *it2 && *it2 < *it1); |
| - } |
| - } |
| + queue.RequestComplete(type, *key1, &request1); |
| + queue.RequestComplete(type, *key2, &request2); |
| } |
| TEST(IdentityMintQueueTest, Empty) { |
| IdentityMintRequestQueue::MintType type = |
| IdentityMintRequestQueue::MINT_TYPE_INTERACTIVE; |
| IdentityMintRequestQueue queue; |
| - std::string extension_id("ext_id"); |
| + scoped_ptr<ExtensionTokenKey> key(ExtensionIdToKey("ext_id")); |
| MockRequest request1; |
| - EXPECT_TRUE(queue.empty(type, extension_id, std::set<std::string>())); |
| + EXPECT_TRUE(queue.empty(type, *key)); |
| EXPECT_CALL(request1, StartMintToken(type)).Times(1); |
| - queue.RequestStart(type, extension_id, std::set<std::string>(), &request1); |
| - EXPECT_FALSE(queue.empty(type, extension_id, std::set<std::string>())); |
| - queue.RequestComplete(type, extension_id, std::set<std::string>(), &request1); |
| - EXPECT_TRUE(queue.empty(type, extension_id, std::set<std::string>())); |
| + queue.RequestStart(type, *key, &request1); |
| + EXPECT_FALSE(queue.empty(type, *key)); |
| + queue.RequestComplete(type, *key, &request1); |
| + EXPECT_TRUE(queue.empty(type, *key)); |
| } |