/*
 * Copyright 2002-2008 the original author or authors.
 *
 * 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.
*/
package integration.anyframe.services.query;

import integration.anyframe.services.AbstractTest;

import java.util.Collection;
import java.util.Iterator;
import java.util.Map;

import anyframe.core.query.IQueryService;

public class QueryServiceTestLob extends AbstractTest {
	/**
	 * 테스트 수행을 위한 main
	 */
	public static void main(String[] args) throws Exception {
		QueryServiceTestLob queryTest = new QueryServiceTestLob();
		// 1. initialize context
		queryTest.setup();
		// 2. testInsertLOB;
		queryTest.testInsertLOB();
		// 3. testSelectLOB;
		queryTest.testSelectLOB();
		// 4. testUpdateLOB;
		queryTest.testUpdateLOB();
		// 5. testDeleteLOB;
		queryTest.testDeleteLOB();
		// 6. close context
		queryTest.teardown();

		System.out.println("Successful!!!!!");
	}

	protected void setup() {
		super.setup();
		try {
			testInit();
		} catch (Exception e) {
			e.printStackTrace();
		}
	}

	/**
	 * 테스트 수행을 위한 table 초기화
	 */
	public void testInit() throws Exception {
		IQueryService queryService = (IQueryService) context
				.getBean("oracle_queryservice");
		try {
			queryService.updateBySQL("DROP TABLE longVarchar", new String[] {},
					new Object[] {});
		} catch (Exception e) {
		}
		queryService.updateBySQL("CREATE TABLE longVarchar ( "
				+ "count  number, " + "myblob blob," + "myclob clob,"
				+ "PRIMARY KEY (count))", new String[] {}, new Object[] {});
	}

	/**
	 * Query 서비스를 통해 DB에 신규 LOB 유형의 데이터를 입력하는 테스트 코드
	 */
	public void testInsertLOB() throws Exception {
		IQueryService queryService = (IQueryService) context
				.getBean("oracle_queryservice");

		String strVal1 = "0무궁화꽃이피었습니다";
		String strVal2 = "1무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "2무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "3무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "4무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "5무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "6무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "7무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "8무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "9무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "10무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "11무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "12무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "13무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "14무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "15무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "16무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "17무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "18무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "19무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "20무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "21무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "22무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "23무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "24무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "25무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "26무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "27무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "28무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "29무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";
		strVal2 += "30무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다무궁화꽃이피었습니다\n";

		int result = queryService.create("insertLOB", new Object[] {
				new Integer(5), strVal1.getBytes(), strVal2 });
		if (result == -1) {
			throw new Exception("LOB insert failed");
		}
	}

	/**
	 * Query 서비스를 통해 DB에 입력된 LOB 유형의 데이터를 조회하는 테스트 코드
	 */
	public void testSelectLOB() throws Exception {
		IQueryService queryService = (IQueryService) context
				.getBean("oracle_queryservice");

		Collection result = queryService.find("selectLOB",
				new Object[] { new Integer(5) });

		Iterator resultItr = result.iterator();
		while (resultItr.hasNext()) {
			Map binary = (Map) resultItr.next();
			String myCLOB = (String) binary.get("myclob");
			String myBLOB = new String((byte[]) binary.get("myblob"));
		}

		if (result.size() != 1) {
			throw new Exception("Select LOB failed");
		}
	}

	/**
	 * Query 서비스를 통해 DB에 입력된 LOB 유형의 데이터를 수정하는 테스트 코드
	 */
	public void testUpdateLOB() throws Exception {
		IQueryService queryService = (IQueryService) context
				.getBean("oracle_queryservice");

		String strVal1 = "0장미꽃이피었습니다";
		String strVal2 = "1장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "2장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "3장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "4장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "5장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "6장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "7장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "8장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "9장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "10장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "11장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "12장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "13장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "14장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "15장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "16장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "17장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "18장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "19장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "20장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "21장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "22장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "23장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "24장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "25장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "26장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "27장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "28장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "29장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";
		strVal2 += "30장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다장미꽃이피었습니다\n";

		int result = queryService.create("updateLOB", new Object[] {
				strVal1.getBytes(), strVal2, new Integer(5) });
	}

	/**
	 * Query 서비스를 통해 DB에 입력된 LOB 유형의 데이터를 삭제하는 테스트 코드
	 */
	public void testDeleteLOB() throws Exception {
		IQueryService queryService = (IQueryService) context
				.getBean("oracle_queryservice");
		queryService.remove("deleteLOB", new Object[] { new Integer(5) });
	}

	protected String[] getConfigLocations() {
		return new String[] {
				"classpath*:/common/applicationContext-*.xml",
				"classpath*:/services/datasource/applicationContext-datasource-oracle.xml",
				"classpath*:/services/query/applicationContext-query-oracle.xml",
				"classpath*:/services/query/applicationContext-query-sqlloader.xml" };
	}
}

