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

Unified Diff: ios/chrome/browser/payments/payment_items_display_view_controller_unittest.mm

Issue 2585233003: Upstream Chrome on iOS source code [2/11]. (Closed)
Patch Set: Created 4 years 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 side-by-side diff with in-line comments
Download patch
Index: ios/chrome/browser/payments/payment_items_display_view_controller_unittest.mm
diff --git a/ios/chrome/browser/payments/payment_items_display_view_controller_unittest.mm b/ios/chrome/browser/payments/payment_items_display_view_controller_unittest.mm
new file mode 100644
index 0000000000000000000000000000000000000000..2d3d92816a5149864102e73a13907f541d961dc6
--- /dev/null
+++ b/ios/chrome/browser/payments/payment_items_display_view_controller_unittest.mm
@@ -0,0 +1,54 @@
+// Copyright 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#import "ios/chrome/browser/payments/payment_items_display_view_controller.h"
+
+#include <vector>
+
+#include "base/mac/foundation_util.h"
+#import "ios/chrome/browser/ui/collection_view/collection_view_controller_test.h"
+#include "ios/chrome/grit/ios_strings.h"
+#include "ios/web/public/payments/payment_request.h"
+#include "testing/gtest/include/gtest/gtest.h"
+
+namespace {
+
+class PaymentItemsDisplayViewControllerTest
+ : public CollectionViewControllerTest {
+ protected:
+ CollectionViewController* NewController() override NS_RETURNS_RETAINED {
+ return [[PaymentItemsDisplayViewController alloc]
+ initWithPayButtonEnabled:YES];
+ }
+
+ PaymentItemsDisplayViewController* PaymentItemsController() {
+ return base::mac::ObjCCastStrict<PaymentItemsDisplayViewController>(
+ controller());
+ }
+};
+
+// Tests that the correct number of items are displayed after loading the model.
+TEST_F(PaymentItemsDisplayViewControllerTest, TestModel) {
+ CreateController();
+ CheckController();
+ CheckTitleWithId(IDS_IOS_PAYMENT_REQUEST_PAYMENT_ITEMS_TITLE);
+
+ std::vector<web::PaymentItem> paymentItems;
+ web::PaymentItem paymentItem;
+ paymentItems.push_back(paymentItem);
+ paymentItems.push_back(paymentItem);
+ paymentItems.push_back(paymentItem);
+
+ [PaymentItemsController() setTotal:paymentItem];
+ [PaymentItemsController() setPaymentItems:paymentItems];
+ [PaymentItemsController() loadModel];
+
+ ASSERT_EQ(1, NumberOfSections());
+ // There should be an item for each of the line items in paymentItems plus 1
+ // for the total.
+ EXPECT_EQ(paymentItems.size() + 1,
+ static_cast<unsigned int>(NumberOfItemsInSection(0)));
+}
+
+} // namespace

Powered by Google App Engine
This is Rietveld 408576698