]> git.saurik.com Git - apt.git/blobdiff - test/libapt/getlanguages_test.cc
evaluate Acquire::Languages= before LANG= (Closes: #602573)
[apt.git] / test / libapt / getlanguages_test.cc
index fb7afb4ef675b0c11960ac67f01f686adf561bdf..3559aae0cbe77a8b84c4d8f388c9e5b7e28078e1 100644 (file)
@@ -16,9 +16,15 @@ void dumpVector(std::vector<std::string> vec) {
 
 int main(int argc,char *argv[])
 {
+       if (argc != 2) {
+               std::cout << "One parameter expected - given " << argc << std::endl;
+               return 100;
+       }
+
        char const* env[2];
        env[0] = "de_DE.UTF-8";
        env[1] = "";
+
        std::vector<std::string> vec = APT::Configuration::getLanguages(false, false, env);
        equals(vec.size(), 2);
        equals(vec[0], "de");
@@ -37,6 +43,13 @@ int main(int argc,char *argv[])
        equals(vec[0], "en_GB");
        equals(vec[1], "en");
 
+       // esperanto
+       env[0] = "eo.UTF-8";
+       vec = APT::Configuration::getLanguages(false, false, env);
+       equals(vec.size(), 2);
+       equals(vec[0], "eo");
+       equals(vec[1], "en");
+
        env[0] = "tr_DE@euro";
        vec = APT::Configuration::getLanguages(false, false, env);
        equals(vec.size(), 2);
@@ -72,6 +85,30 @@ int main(int argc,char *argv[])
        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";
@@ -87,6 +124,16 @@ int main(int argc,char *argv[])
        equals(vec[0], "de");
        equals(vec[1], "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");
+
+       _config->Set("Dir::State::lists", "/non-existing-dir");
        _config->Set("Acquire::Languages::1", "none");
        env[0] = "de_DE.UTF-8";
        vec = APT::Configuration::getLanguages(false, false, env);
@@ -113,12 +160,14 @@ int main(int argc,char *argv[])
                _config->Set("APT::Acquire::Translation", "ast_DE");
                env[0] = "de_DE.UTF-8";
                vec = APT::Configuration::getLanguages(true, false, env);
-               equals(vec.size(), 1);
+               equals(vec.size(), 2);
                equals(vec[0], "ast_DE");
+               equals(vec[1], "en");
                _config->Set("APT::Acquire::Translation", "none");
                env[0] = "de_DE.UTF-8";
                vec = APT::Configuration::getLanguages(true, false, env);
-               equals(vec.size(), 0);
+               equals(vec.size(), 1);
+               equals(vec[0], "en");
 
        return 0;
 }