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

Side by Side Diff: chrome/browser/encoding_menu_controller_unittest.cc

Issue 5544002: Move a bunch more browser stuff around.... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 10 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "chrome/browser/encoding_menu_controller.h"
6
7 #include <string>
8
9 #include "base/basictypes.h"
10 #include "chrome/app/chrome_command_ids.h"
11 #include "chrome/browser/prefs/pref_service.h"
12 #include "chrome/browser/profile.h"
13 #include "chrome/common/pref_names.h"
14 #include "chrome/test/testing_profile.h"
15 #include "testing/gtest/include/gtest/gtest.h"
16
17
18 class EncodingMenuControllerTest : public testing::Test {
19 };
20
21 TEST_F(EncodingMenuControllerTest, EncodingIDsBelongTest) {
22 EncodingMenuController controller;
23
24 // Check some bogus ids to make sure they're never valid.
25 ASSERT_FALSE(controller.DoesCommandBelongToEncodingMenu(0));
26 ASSERT_FALSE(controller.DoesCommandBelongToEncodingMenu(-1));
27
28 int num_valid_encoding_ids = controller.NumValidGUIEncodingIDs();
29 const int* valid_encodings = controller.ValidGUIEncodingIDs();
30 ASSERT_TRUE(controller.DoesCommandBelongToEncodingMenu(
31 IDC_ENCODING_AUTO_DETECT));
32 // Check that all valid encodings are accepted.
33 for (int i = 0; i < num_valid_encoding_ids; ++i) {
34 ASSERT_TRUE(controller.DoesCommandBelongToEncodingMenu(valid_encodings[i]));
35 }
36
37 // This test asserts that we haven't added a new valid ID without including it
38 // in the kValidEncodingIds test list above.
39 // The premise is that new encodings will be added directly after the current
40 // ones so we'll catch such cases.
41 int one_past_largest_id = valid_encodings[num_valid_encoding_ids - 1] + 1;
42 ASSERT_FALSE(controller.DoesCommandBelongToEncodingMenu(one_past_largest_id));
43 }
44
45 TEST_F(EncodingMenuControllerTest, ListEncodingMenuItems) {
46 typedef EncodingMenuController::EncodingMenuItemList EncodingMenuItemList;
47 EncodingMenuController controller;
48
49 EncodingMenuItemList english_items;
50 TestingProfile profile_en;
51
52 controller.GetEncodingMenuItems(&profile_en, &english_items);
53
54 // Make sure there are items in the lists.
55 ASSERT_TRUE(english_items.size() > 0);
56 // Make sure that autodetect is the first item on both menus
57 ASSERT_EQ(english_items[0].first, IDC_ENCODING_AUTO_DETECT);
58 }
59
60 TEST_F(EncodingMenuControllerTest, IsItemChecked) {
61 TestingProfile profile_en;
62 std::string encoding("UTF-8");
63
64 // Check that enabling and disabling autodetect works.
65 bool autodetect_enabed[] = {true, false};
66 PrefService* prefs = profile_en.GetPrefs();
67 EncodingMenuController controller;
68 for (size_t i = 0; i < arraysize(autodetect_enabed); ++i) {
69 bool enabled = autodetect_enabed[i];
70 prefs->SetBoolean(prefs::kWebKitUsesUniversalDetector, enabled);
71 ASSERT_TRUE(controller.IsItemChecked(&profile_en,
72 encoding,
73 IDC_ENCODING_AUTO_DETECT) == enabled);
74 }
75
76 // Check all valid encodings, make sure only one is enabled when autodetection
77 // is turned off.
78 prefs->SetBoolean(prefs::kWebKitUsesUniversalDetector, false);
79 bool encoding_is_enabled = false;
80 size_t num_valid_encoding_ids = controller.NumValidGUIEncodingIDs();
81 const int* valid_encodings = controller.ValidGUIEncodingIDs();
82 for (size_t i = 0; i < num_valid_encoding_ids; ++i) {
83 bool on = controller.IsItemChecked(&profile_en,
84 encoding,
85 valid_encodings[i]);
86 // Only one item in the encoding menu can be selected at a time.
87 ASSERT_FALSE(on && encoding_is_enabled);
88 encoding_is_enabled |= on;
89 }
90
91 // Make sure at least one encoding is enabled.
92 ASSERT_TRUE(encoding_is_enabled);
93 }
OLDNEW
« no previous file with comments | « chrome/browser/encoding_menu_controller.cc ('k') | chrome/browser/extensions/extension_popup_api.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698