]> git.saurik.com Git - apt.git/blobdiff - test/libapt/getlanguages_test.cc
refresh po/*
[apt.git] / test / libapt / getlanguages_test.cc
index 0db190b507b9a0ff76ca78407d5f2fd4bcb99914..3d63e0e7475f726fbbab897ec0260a7bf6191cef 100644 (file)
@@ -26,16 +26,18 @@ int main(int argc,char *argv[])
        env[1] = "";
 
        std::vector<std::string> vec = APT::Configuration::getLanguages(false, false, env);
-       equals(vec.size(), 2);
-       equals(vec[0], "de");
-       equals(vec[1], "en");
+       equals(vec.size(), 3);
+       equals(vec[0], "de_DE");
+       equals(vec[1], "de");
+       equals(vec[2], "en");
 
        // Special: Check if the cache is actually in use
                env[0] = "en_GB.UTF-8";
                vec = APT::Configuration::getLanguages(false, true, env);
-               equals(vec.size(), 2);
-               equals(vec[0], "de");
-               equals(vec[1], "en");
+               equals(vec.size(), 3);
+               equals(vec[0], "de_DE");
+               equals(vec[1], "de");
+               equals(vec[2], "en");
 
        env[0] = "en_GB.UTF-8";
        vec = APT::Configuration::getLanguages(false, false, env);
@@ -43,21 +45,30 @@ int main(int argc,char *argv[])
        equals(vec[0], "en_GB");
        equals(vec[1], "en");
 
-       env[0] = "tr_DE@euro";
+       // esperanto
+       env[0] = "eo.UTF-8";
        vec = APT::Configuration::getLanguages(false, false, env);
        equals(vec.size(), 2);
-       equals(vec[0], "tr");
+       equals(vec[0], "eo");
        equals(vec[1], "en");
 
+       env[0] = "tr_DE@euro";
+       vec = APT::Configuration::getLanguages(false, false, env);
+       equals(vec.size(), 3);
+       equals(vec[0], "tr_DE");
+       equals(vec[1], "tr");
+       equals(vec[2], "en");
+
        env[0] = "de_NO";
-       env[1] = "se_NO:en_GB:nb_NO:nb:no_NO:no:nn_NO:nn:da:sv:en";
+       env[1] = "de_NO:en_GB:nb_NO:nb:no_NO:no:nn_NO:nn:da:sv:en";
        vec = APT::Configuration::getLanguages(false, false, env);
-       equals(vec.size(), 5);
-       equals(vec[0], "de");
-       equals(vec[1], "en_GB");
-       equals(vec[2], "nb");
-       equals(vec[3], "no");
-       equals(vec[4], "en");
+       equals(vec.size(), 6);
+       equals(vec[0], "de_NO");
+       equals(vec[1], "de");
+       equals(vec[2], "en_GB");
+       equals(vec[3], "nb_NO");
+       equals(vec[4], "nb");
+       equals(vec[5], "en");
 
        env[0] = "pt_PR.UTF-8";
        env[1] = "";
@@ -69,38 +80,66 @@ int main(int argc,char *argv[])
 
        env[0] = "ast_DE.UTF-8";
        vec = APT::Configuration::getLanguages(false, false, env); // bogus, but syntactical correct
-       equals(vec.size(), 2);
-       equals(vec[0], "ast");
-       equals(vec[1], "en");
+       equals(vec.size(), 3);
+       equals(vec[0], "ast_DE");
+       equals(vec[1], "ast");
+       equals(vec[2], "en");
+
+       env[0] = "C";
+       vec = APT::Configuration::getLanguages(false, false, env);
+       equals(vec.size(), 1);
+       equals(vec[0], "en");
+
+       _config->Set("Acquire::Languages", "none");
+       env[0] = "C";
+       vec = APT::Configuration::getLanguages(false, false, env);
+       equals(vec.size(), 0);
 
+       _config->Set("Acquire::Languages", "environment");
        env[0] = "C";
        vec = APT::Configuration::getLanguages(false, false, env);
        equals(vec.size(), 1);
        equals(vec[0], "en");
 
+       _config->Set("Acquire::Languages", "de");
+       env[0] = "C";
+       vec = APT::Configuration::getLanguages(false, false, env);
+       equals(vec.size(), 1);
+       equals(vec[0], "de");
+
+       _config->Set("Acquire::Languages", "fr");
+       env[0] = "ast_DE.UTF-8";
+       vec = APT::Configuration::getLanguages(false, false, env);
+       equals(vec.size(), 1);
+       equals(vec[0], "fr");
+       _config->Set("Acquire::Languages", "");
+
        _config->Set("Acquire::Languages::1", "environment");
        _config->Set("Acquire::Languages::2", "en");
        env[0] = "de_DE.UTF-8";
        vec = APT::Configuration::getLanguages(false, false, env);
-       equals(vec.size(), 2);
-       equals(vec[0], "de");
-       equals(vec[1], "en");
+       equals(vec.size(), 3);
+       equals(vec[0], "de_DE");
+       equals(vec[1], "de");
+       equals(vec[2], "en");
 
        _config->Set("Acquire::Languages::3", "de");
        env[0] = "de_DE.UTF-8";
        vec = APT::Configuration::getLanguages(false, false, env);
-       equals(vec.size(), 2);
-       equals(vec[0], "de");
-       equals(vec[1], "en");
+       equals(vec.size(), 3);
+       equals(vec[0], "de_DE");
+       equals(vec[1], "de");
+       equals(vec[2], "en");
 
        _config->Set("Dir::State::lists", argv[1]);
        vec = APT::Configuration::getLanguages(true, false, env);
-       equals(vec.size(), 5);
-       equals(vec[0], "de");
-       equals(vec[1], "en");
-       equals(vec[2], "none");
-       equals(vec[3], "pt");
-       equals(vec[4], "tr");
+       equals(vec.size(), 6);
+       equals(vec[0], "de_DE");
+       equals(vec[1], "de");
+       equals(vec[2], "en");
+       equals(vec[3], "none");
+       equalsOr2(vec[4], "pt", "tr");
+       equalsOr2(vec[5], "tr", "pt");
 
        _config->Set("Dir::State::lists", "/non-existing-dir");
        _config->Set("Acquire::Languages::1", "none");
@@ -109,6 +148,7 @@ int main(int argc,char *argv[])
        equals(vec.size(), 0);
        env[0] = "de_DE.UTF-8";
        vec = APT::Configuration::getLanguages(true, false, env);
+       equals(vec.size(), 2);
        equals(vec[0], "en");
        equals(vec[1], "de");