os/ossrv/glib/tests/list-env.c
changeset 0 bde4ae8d615e
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/os/ossrv/glib/tests/list-env.c	Fri Jun 15 03:10:57 2012 +0200
     1.3 @@ -0,0 +1,98 @@
     1.4 +// Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
     1.5 +// All rights reserved.
     1.6 +// This component and the accompanying materials are made available
     1.7 +// under the terms of "Eclipse Public License v1.0"
     1.8 +// which accompanies this distribution, and is available
     1.9 +// at the URL "http://www.eclipse.org/legal/epl-v10.html".
    1.10 +//
    1.11 +// Initial Contributors:
    1.12 +// Nokia Corporation - initial contribution.
    1.13 +//
    1.14 +// Contributors:
    1.15 +//
    1.16 +// Description:
    1.17 +//
    1.18 +
    1.19 +#undef G_DISABLE_ASSERT
    1.20 +#undef G_LOG_DOMAIN
    1.21 +
    1.22 +#include <glib.h>
    1.23 +#include <errno.h>
    1.24 +#define LOG_FILE "c:\\logs\\list_env_log.txt"
    1.25 +#include "std_log_result.h"
    1.26 +#define LOG_FILENAME_LINE __FILE__, __LINE__
    1.27 +
    1.28 +void create_xml(int result)
    1.29 +{
    1.30 +    if(result)
    1.31 +        assert_failed = 1;
    1.32 +    
    1.33 +    testResultXml("list_env_log");
    1.34 +    close_log_file();
    1.35 +}
    1.36 +
    1.37 +int main (int argc, char *argv[])
    1.38 +{
    1.39 +    const gchar *variable1 = "TEST_VAR1";
    1.40 +    gchar *value1 = "testvalue1";
    1.41 +    const gchar *variable2 = "TEST_VAR2";
    1.42 +    gchar *value2 = "testvalue2";
    1.43 +    gchar **env_list;
    1.44 +    gint i, found = 0;
    1.45 +    guint no_of_variables =0;
    1.46 +    gboolean found_var1 = 0,  found_var2 = 0;
    1.47 +    	
    1.48 +    if(g_setenv (variable1, value1, TRUE) && g_setenv (variable2, value2, TRUE))
    1.49 +        {
    1.50 +        env_list = g_listenv();
    1.51 +        
    1.52 +        if(env_list)
    1.53 +            {
    1.54 +            no_of_variables = g_strv_length(env_list);
    1.55 +            
    1.56 +            if(no_of_variables)
    1.57 +                {
    1.58 +                for(i = 0; i<no_of_variables; i++)
    1.59 +                    {
    1.60 +                    gchar *data = env_list[i];
    1.61 +                    
    1.62 +                    if(g_strcmp0(data, variable1) == 0)
    1.63 +                        found_var1 = 1;
    1.64 +                    else if(g_strcmp0(data, variable2) == 0)
    1.65 +                        found_var2 = 1;
    1.66 +                    }
    1.67 +                
    1.68 +                if(!(found_var1 && found_var2))
    1.69 +                    {
    1.70 +                    std_log(LOG_FILENAME_LINE, "g_listenv failed");
    1.71 +                    assert_failed = 1;
    1.72 +                    }
    1.73 +                }
    1.74 +            else
    1.75 +                {
    1.76 +                std_log(LOG_FILENAME_LINE, "g_listenv returned list is of length 0");
    1.77 +                assert_failed = 1;
    1.78 +                }
    1.79 +            
    1.80 +            g_strfreev(env_list);
    1.81 +            }
    1.82 +        else
    1.83 +            {
    1.84 +            std_log(LOG_FILENAME_LINE, "g_listenv returned NULL");
    1.85 +            assert_failed = 1;
    1.86 +            }
    1.87 +        }
    1.88 +    else
    1.89 +        {
    1.90 +        std_log(LOG_FILENAME_LINE, "setting env variable failed. errno = %d", errno);
    1.91 +        }
    1.92 +    
    1.93 +    if(assert_failed)
    1.94 +          std_log(LOG_FILENAME_LINE,"Test Failed");
    1.95 +    else
    1.96 +          std_log(LOG_FILENAME_LINE,"Test Successful");
    1.97 +	
    1.98 +    create_xml(0);
    1.99 +
   1.100 +	return 0;
   1.101 +}