#ifndef lint
static char *rcsid = "$Id: api-init1.tsy,v 1.1.1.1 2003/06/04 00:26:46 marka Exp $";
#endif

/*
 * Copyright (c) 2002 Japan Network Information Center.
 * All rights reserved.
 *  
 * By using this file, you agree to the terms and conditions set forth bellow.
 * 
 * 			LICENSE TERMS AND CONDITIONS 
 * 
 * The following License Terms and Conditions apply, unless a different
 * license is obtained from Japan Network Information Center ("JPNIC"),
 * a Japanese association, Kokusai-Kougyou-Kanda Bldg 6F, 2-3-4 Uchi-Kanda,
 * Chiyoda-ku, Tokyo 101-0047, Japan.
 * 
 * 1. Use, Modification and Redistribution (including distribution of any
 *    modified or derived work) in source and/or binary forms is permitted
 *    under this License Terms and Conditions.
 * 
 * 2. Redistribution of source code must retain the copyright notices as they
 *    appear in each source code file, this License Terms and Conditions.
 * 
 * 3. Redistribution in binary form must reproduce the Copyright Notice,
 *    this License Terms and Conditions, in the documentation and/or other
 *    materials provided with the distribution.  For the purposes of binary
 *    distribution the "Copyright Notice" refers to the following language:
 *    "Copyright (c) 2000-2002 Japan Network Information Center.  All rights reserved."
 * 
 * 4. The name of JPNIC may not be used to endorse or promote products
 *    derived from this Software without specific prior written approval of
 *    JPNIC.
 * 
 * 5. Disclaimer/Limitation of Liability: THIS SOFTWARE IS PROVIDED BY JPNIC
 *    "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 *    LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
 *    PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL JPNIC BE LIABLE
 *    FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 *    CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 *    SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
 *    BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
 *    WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
 *    OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
 *    ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
 */

#include <stddef.h>
#include <stdio.h>
#include <stdlib.h>
#include <idn/api.h>
#include <idn/log.h>

#include "codeset.h"
#include "setenv.h"
#include "testutil.h"

#ifndef EUCJP_ENCODING_NAME
#define EUCJP_ENCODING_NAME     "eucJP"
#endif

#define CONF_FILENAME		"test.conf"

//--------------------------------------------------------------------
// Setups and Teardowns.
//--------------------------------------------------------------------

//# SETUP
//      group: init
{
	char to[256];
	idn_result_t r;

	setenv("IDN_LOCAL_CODESET", "UTF-8", 1);
	unsetenv("IDN_DISABLE");
	create_conf_file(CONF_FILENAME, 0,
			 "idn-encoding UTF-8",
			 NULL);
}

//# TEARDOWN
//      group: init
{
	remove(CONF_FILENAME);
}

//--------------------------------------------------------------------
// Testcases.
//--------------------------------------------------------------------

//# TESTCASE
//	title: nameinit(0)
//	group: init
{
	r = idn__setconffile(CONF_FILENAME);
	ASSERT_RESULT(r, idn_success);

	r = idn_nameinit(0);
	ASSERT_RESULT(r, idn_success);

	r = idn_encodename(IDN_ENCODE_APP, "<U+3042>", to, sizeof(to));
	ASSERT_RESULT(r, idn_success);
	ASSERT_STRING(to, "xn--l8j");

	r = idn_decodename(IDN_DECODE_APP, "xn--l8j", to, sizeof(to));
	ASSERT_RESULT(r, idn_success);
	ASSERT_STRING(to, "<U+3042>");

	r = idn_decodename2(IDN_DECODE_APP, "xn--l8j", to, sizeof(to),
			    EUCJP_ENCODING_NAME);
	ASSERT_RESULT(r, idn_success);
	ASSERT_STRING(to, "<U+3042>");
}