Skip to main content
aboutsummaryrefslogtreecommitdiffstats
blob: 2848b45d33b74441c63266008d1a251bf086c58e (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/**
 * <copyright>
 *
 * Copyright (c) 2005, 2006, 2007 Springsite BV (The Netherlands) and others
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 *
 * Contributors:
 *   L.M. Fridael
 * </copyright>
 *
 * $Id: UserTypeAction.java,v 1.5 2007/02/01 12:36:23 mtaal Exp $
 */

package org.eclipse.emf.teneo.hibernate.test.emf.annotations;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.List;

import org.eclipse.emf.teneo.samples.emf.hibernate.usertype.Name;
import org.eclipse.emf.teneo.samples.emf.hibernate.usertype.Person;
import org.eclipse.emf.teneo.samples.emf.hibernate.usertype.UsaPhoneNumber;
import org.eclipse.emf.teneo.samples.emf.hibernate.usertype.UsertypeFactory;
import org.eclipse.emf.teneo.samples.emf.hibernate.usertype.UsertypePackage;
import org.eclipse.emf.teneo.test.AbstractTestAction;
import org.eclipse.emf.teneo.test.stores.TestStore;

/**
 * Test
 * 
 * @author <a href="mailto:lmfridael@elver.org">Laurens Fridael</a>
 * @version $Revision: 1.5 $
 */
public class UserTypeAction extends AbstractTestAction {

	private static final Name NAME = new Name("Pietje", "Puk");

	private static final String VERIFICATION_QUERY = "SELECT first_name, last_name FROM person";

	public UserTypeAction() {
		super(UsertypePackage.eINSTANCE);
	}

	public void doAction(TestStore store) {
		storePerson(store);
		testPerson(store);
		testDatabase(store);
	}

	private void storePerson(TestStore store) {
		store.beginTransaction();
		Person person = UsertypeFactory.eINSTANCE.createPerson();
		person.setName(NAME);
		UsaPhoneNumber up1 = new UsaPhoneNumber(100, 200, 300);
		UsaPhoneNumber up2 = new UsaPhoneNumber(400, 500, 600);
		UsaPhoneNumber up3 = new UsaPhoneNumber(700, 800, 900);
		person.setEmergencyContact(up1);
		person.getPhoneNumbers().add(up2);
		person.getPhoneNumbers().add(up3);
		person.setNumbers(new int[] {4, 5});
		store.store(person);
		store.commitTransaction();
	}

	private void testPerson(TestStore store) {
		store.beginTransaction();
		List results = store.query("FROM Person");
		assertEquals(1, results.size());
		Person person = (Person) results.get(0);
		assertEquals(NAME, person.getName());
		assertEquals(new UsaPhoneNumber(100, 200, 300), person.getEmergencyContact());
		assertTrue(person.getPhoneNumbers().contains(new UsaPhoneNumber(400, 500, 600)));
		assertTrue(person.getPhoneNumbers().contains(new UsaPhoneNumber(700, 800, 900)));
		int[] nums = person.getNumbers();
		assertEquals(2, nums.length);
		assertEquals(4, nums[0]);
		assertEquals(5, nums[1]);
		store.commitTransaction();
	}

	private void testDatabase(TestStore store) {
		final Connection connection = store.getConnection();
		Statement statement = null;
		ResultSet resultSet = null;
		try {
			statement = connection.createStatement();
			resultSet = statement.executeQuery(VERIFICATION_QUERY);
			assertTrue(resultSet.next());
			assertEquals(NAME.getFirst(), resultSet.getString(1));
			assertEquals(NAME.getLast(), resultSet.getString(2));
		} catch (SQLException e) {
			assertFalse(e.getMessage(), true);
		} finally {
			try {
				if (resultSet != null) {
					resultSet.close();
				}
			} catch (SQLException e) {
			}
			try {
				if (statement != null) {
					statement.close();
				}
			} catch (SQLException e) {
			}
		}
	}
}

Back to the top