blob: 0ddd06795ecd3fb6cb59304d0fb0bfb4a4f82933 [file] [log] [blame]
// Copyright (C) 2013 Google Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#include <libaddressinput/localization.h>
#include <string>
#include <gtest/gtest.h>
#include "grit.h"
#include "messages.h"
namespace {
using i18n::addressinput::INVALID_MESSAGE_ID;
using i18n::addressinput::Localization;
// Tests for Localization object.
class LocalizationTest : public testing::TestWithParam<int> {
protected:
Localization localization_;
};
// Verifies that a custom message getter can be used.
const char kValidMessage[] = "Data";
std::string GetValidMessage(int message_id) { return kValidMessage; }
TEST_P(LocalizationTest, ValidStringGetterCanBeUsed) {
localization_.SetGetter(&GetValidMessage);
EXPECT_EQ(kValidMessage, localization_.GetString(GetParam()));
}
// Verifies that the default language for messages does not have empty strings.
TEST_P(LocalizationTest, DefaultStringIsNotEmpty) {
EXPECT_FALSE(localization_.GetString(GetParam()).empty());
}
// Verifies that English is the default language.
TEST_P(LocalizationTest, EnglishIsDefaultLanguage) {
std::string default_string = localization_.GetString(GetParam());
localization_.SetLanguage("en");
EXPECT_EQ(default_string, localization_.GetString(GetParam()));
}
// Tests all message identifiers.
INSTANTIATE_TEST_CASE_P(
AllMessages, LocalizationTest,
testing::Values(IDS_LIBADDRESSINPUT_I18N_COUNTRY_LABEL,
IDS_LIBADDRESSINPUT_I18N_LOCALITY_LABEL,
IDS_LIBADDRESSINPUT_I18N_DEPENDENT_LOCALITY_LABEL,
IDS_LIBADDRESSINPUT_I18N_ORGANIZATION_LABEL,
IDS_LIBADDRESSINPUT_I18N_RECIPIENT_LABEL,
IDS_LIBADDRESSINPUT_I18N_ADDRESS_LINE1_LABEL,
IDS_LIBADDRESSINPUT_I18N_POSTAL_CODE_LABEL,
IDS_LIBADDRESSINPUT_I18N_ZIP_CODE_LABEL,
IDS_LIBADDRESSINPUT_I18N_CEDEX_LABEL,
IDS_LIBADDRESSINPUT_I18N_AREA,
IDS_LIBADDRESSINPUT_I18N_COUNTY_LABEL,
IDS_LIBADDRESSINPUT_I18N_DEPARTMENT,
IDS_LIBADDRESSINPUT_I18N_DO_SI,
IDS_LIBADDRESSINPUT_I18N_EMIRATE,
IDS_LIBADDRESSINPUT_I18N_ISLAND,
IDS_LIBADDRESSINPUT_I18N_PARISH,
IDS_LIBADDRESSINPUT_I18N_PREFECTURE,
IDS_LIBADDRESSINPUT_I18N_PROVINCE,
IDS_LIBADDRESSINPUT_I18N_STATE_LABEL));
// Verifies that an invalid message identifier results in an empty string in the
// default configuration.
TEST_F(LocalizationTest, InvalidMessageIsEmptyString) {
EXPECT_TRUE(localization_.GetString(INVALID_MESSAGE_ID).empty());
}
} // namespace