From e6c31d508ddebc6c3d28e31e27e6f2239db5f6d9 Mon Sep 17 00:00:00 2001 From: Carlos Nihelton Date: Mon, 18 Sep 2023 22:49:00 -0300 Subject: [PATCH] Updates tests and stubs Removes coroutine and WinRT related headers, Updates stubs methods Removes no longer relevant test for user id size No test should isntantiate production Context --- storeapi/test/CMakeLists.txt | 2 +- storeapi/test/ServerStoreServiceTest.cpp | 39 ++++++++------- storeapi/test/stubs.hpp | 63 ++++++++++++++---------- 3 files changed, 57 insertions(+), 47 deletions(-) diff --git a/storeapi/test/CMakeLists.txt b/storeapi/test/CMakeLists.txt index 516959ad3..5ac438c09 100644 --- a/storeapi/test/CMakeLists.txt +++ b/storeapi/test/CMakeLists.txt @@ -15,7 +15,7 @@ set(StoreApi_SRCS "../base/Exception.hpp" "../base/Purchase.hpp" "../base/StoreService.hpp" - "../agent/ServerStoreService.cpp" + "../agent/ServerStoreService.hpp" "../gui/ClientStoreService.hpp" ) diff --git a/storeapi/test/ServerStoreServiceTest.cpp b/storeapi/test/ServerStoreServiceTest.cpp index a2e154405..2162b67ae 100644 --- a/storeapi/test/ServerStoreServiceTest.cpp +++ b/storeapi/test/ServerStoreServiceTest.cpp @@ -8,41 +8,42 @@ namespace StoreApi { using namespace ::testing; -TEST(UserInfo, PredictableSizes) { - auto user = UserInfo::Current().get(); - auto size = user.id.size(); - EXPECT_TRUE(size == 0 || size == 64) - << "User ID of unexpected size: " << size << " <" - << winrt::to_string(user.id) << '\n'; +TEST(ServerStoreService, NoUsersLikeInCI) { + auto service = ServerStoreService{}; + EXPECT_THROW({auto user = service.CurrentUserInfo();}, Exception); +} + +TEST(ServerStoreService, TooManyUsers) { + auto service = ServerStoreService{}; + EXPECT_THROW({auto user = service.CurrentUserInfo();}, Exception); +} + +TEST(ServerStoreService, FindOneUser) { + static constexpr char goodHash[] = "goodHash"; + auto service = ServerStoreService{}; + FindOneUser::goodHash = goodHash; + auto user = service.CurrentUserInfo(); + EXPECT_EQ(user.id, goodHash); } TEST(ServerStoreService, EmptyJwtThrows) { auto service = ServerStoreService{}; - UserInfo user{.id = L"my@name.com"}; + UserInfo user{.id = "my@name.com"}; EXPECT_THROW( { - auto jwt = service.GenerateUserJwt("this-is-a-web-token", user).get(); + auto jwt = service.GenerateUserJwt("this-is-a-web-token", user); }, Exception); } TEST(ServerStoreService, NonEmptyJwtNeverThrows) { auto service = ServerStoreService{}; - UserInfo user{.id = L"my@name.com"}; + UserInfo user{.id = "my@name.com"}; std::string token{"this-is-a-web-token"}; - auto jwt = service.GenerateUserJwt(token, user).get(); + auto jwt = service.GenerateUserJwt(token, user); EXPECT_EQ(token, jwt); } -TEST(ServerStoreService, RealServerFailsUnderTest) { - auto service = ServerStoreService{}; - UserInfo user{.id = L"my@name.com"}; - std::string token{"this-is-a-web-token"}; - // This fails because the test is not an app deployed through the store. - EXPECT_THROW({ auto jwt = service.GenerateUserJwt(token, user).get(); }, - Exception); -} - TEST(ServerStoreService, ExpirationDateUnsubscribed) { auto service = ServerStoreService{}; diff --git a/storeapi/test/stubs.hpp b/storeapi/test/stubs.hpp index 2a101fda4..86accbcec 100644 --- a/storeapi/test/stubs.hpp +++ b/storeapi/test/stubs.hpp @@ -4,23 +4,16 @@ #include #include -// For WinRT basic types and coroutines. -#include -// For non-WinRT coroutines -#include - -// Win32 APIs, such as the Timezone -#include - #include #include #include #include #include #include +// For timegm +#include #if defined _MSC_VER -#include #include #define timegm _mkgmtime #endif @@ -89,9 +82,8 @@ struct EmptyJwtContext { return {Product{.kind = kinds[0], .id = ids[0]}}; } - winrt::Windows::Foundation::IAsyncOperation GenerateUserJwt( - winrt::hstring hToken, winrt::hstring hUserId) { - co_return {}; + std::string GenerateUserJwt(std::string hToken, std::string hUserId) const { + return {}; } }; @@ -107,9 +99,8 @@ struct IdentityJwtContext { return {Product{.kind = kinds[0], .id = ids[0]}}; } - winrt::Windows::Foundation::IAsyncOperation GenerateUserJwt( - winrt::hstring hToken, winrt::hstring hUserId) { - co_return hToken; + std::string GenerateUserJwt(std::string hToken, std::string hUserId) const { + return hToken; } }; @@ -132,9 +123,8 @@ struct NeverSubscribedContext { return {Product{.kind = kinds[0], .id = ids[0]}}; } - winrt::Windows::Foundation::IAsyncOperation GenerateUserJwt( - winrt::hstring hToken, winrt::hstring hUserId) { - co_return hToken; + std::string GenerateUserJwt(std::string hToken, std::string hUserId) const { + return hToken; } }; @@ -158,9 +148,8 @@ struct UnixEpochContext { return {Product{.kind = kinds[0], .id = ids[0]}}; } - winrt::Windows::Foundation::IAsyncOperation GenerateUserJwt( - winrt::hstring hToken, winrt::hstring hUserId) { - co_return hToken; + std::string GenerateUserJwt(std::string hToken, std::string hUserId) const { + return hToken; } }; @@ -187,9 +176,8 @@ struct AlreadyPurchasedContext { return {Product{.kind = kinds[0], .id = ids[0]}}; } - winrt::Windows::Foundation::IAsyncOperation GenerateUserJwt( - winrt::hstring hToken, winrt::hstring hUserId) { - co_return hToken; + std::string GenerateUserJwt(std::string hToken, std::string hUserId) const { + return hToken; } // noop @@ -219,11 +207,32 @@ struct PurchaseSuccessContext { return {Product{.kind = kinds[0], .id = ids[0]}}; } - winrt::Windows::Foundation::IAsyncOperation GenerateUserJwt( - winrt::hstring hToken, winrt::hstring hUserId) { - co_return hToken; + std::string GenerateUserJwt(std::string hToken, std::string hUserId) const { + return hToken; } // noop void InitDialogs(Window window) {} }; + +struct TooManyUsersContext { + struct Product {}; + std::vector AllLocallyAuthenticatedUserHashes() const { + return {"first-user", "second-user"}; + } +}; + +struct NoUsers { + struct Product {}; + std::vector AllLocallyAuthenticatedUserHashes() const { + return {}; + } +}; + +struct FindOneUser { + struct Product {}; + static inline std::string goodHash{}; + std::vector AllLocallyAuthenticatedUserHashes() const { + return {goodHash}; + } +};