/* * Copyright 2010-2013 Ning, Inc. * * Ning licenses this file to you 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 org.killbill.billing.util.dao; import java.io.IOException; import java.util.Date; import java.util.UUID; import org.skife.jdbi.v2.Handle; import org.skife.jdbi.v2.tweak.HandleCallback; import org.testng.Assert; import org.testng.annotations.Test; import org.killbill.billing.ObjectType; import org.killbill.billing.util.UtilTestSuiteWithEmbeddedDB; public class TestNonEntityDao extends UtilTestSuiteWithEmbeddedDB { final Long tenantRecordId = 123123123L; final UUID tenantId = UUID.fromString("121c59d4-0458-4038-a683-698c9a121c12"); final UUID accountId = UUID.fromString("a01c59d4-0458-4038-a683-698c9a121c69"); final Long accountRecordId = 333333L; final UUID tagDefinitionId = UUID.fromString("e01c59d4-0458-4038-a683-698c9a121c34"); final Long tagDefinitionRecordId = 44444444L; final UUID tagId = UUID.fromString("123c59d4-0458-4038-a683-698c9a121456"); final Long tagRecordId = 55555555L; @Test(groups = "slow") public void testRetrieveRecordIdFromObject() throws IOException { insertAccount(); final Long resultRecordId = nonEntityDao.retrieveRecordIdFromObject(accountId, ObjectType.ACCOUNT, null); Assert.assertEquals(resultRecordId, accountRecordId); } @Test(groups = "slow") public void testRetrieveAccountRecordIdFromAccountObject() throws IOException { insertAccount(); final Long resultAccountRecordId = nonEntityDao.retrieveAccountRecordIdFromObject(accountId, ObjectType.ACCOUNT, null); Assert.assertEquals(resultAccountRecordId, accountRecordId); } @Test(groups = "slow") public void testRetrieveAccountRecordIdFromTagDefinitionObject() throws IOException { insertTagDefinition(); final Long resultAccountRecordId = nonEntityDao.retrieveAccountRecordIdFromObject(tagDefinitionId, ObjectType.TAG_DEFINITION, null); Assert.assertEquals(resultAccountRecordId, null); } // Not Tag_definition or account which are special @Test(groups = "slow") public void testRetrieveAccountRecordIdFromOtherObject() throws IOException { insertTag(); final Long resultAccountRecordId = nonEntityDao.retrieveAccountRecordIdFromObject(tagId, ObjectType.TAG, null); Assert.assertEquals(resultAccountRecordId, accountRecordId); } @Test(groups = "slow") public void testRetrieveTenantRecordIdFromObject() throws IOException { insertAccount(); final Long resultTenantRecordId = nonEntityDao.retrieveTenantRecordIdFromObject(accountId, ObjectType.ACCOUNT, null); Assert.assertEquals(resultTenantRecordId, tenantRecordId); } @Test(groups = "slow") public void testRetrieveTenantRecordIdFromTenantObject() throws IOException { insertTenant(); final Long resultTenantRecordId = nonEntityDao.retrieveTenantRecordIdFromObject(tenantId, ObjectType.TENANT, null); Assert.assertEquals(resultTenantRecordId, tenantRecordId); } private void insertAccount() throws IOException { dbi.withHandle(new HandleCallback<Void>() { @Override public Void withHandle(final Handle handle) throws Exception { // Note: we always create an accounts table, see MysqlTestingHelper handle.execute("insert into accounts (record_id, id, email, name, first_name_length, is_notified_for_invoices, created_date, created_by, updated_date, updated_by, tenant_record_id) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)", accountRecordId, accountId.toString(), "zozo@tt.com", "zozo", 4, false, new Date(), "i", new Date(), "j", tenantRecordId); return null; } }); } private void insertHistoryAccount() throws IOException { dbi.withHandle(new HandleCallback<Void>() { @Override public Void withHandle(final Handle handle) throws Exception { // Note: we always create an accounts table, see MysqlTestingHelper handle.execute("insert into account_history (record_id, id, email, name, first_name_length, is_notified_for_invoices, created_date, created_by, updated_date, updated_by, tenant_record_id) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)", accountRecordId, accountId.toString(), "zozo@tt.com", "zozo", 4, false, new Date(), "i", new Date(), "j", tenantRecordId); return null; } }); } private void insertTagDefinition() throws IOException { dbi.withHandle(new HandleCallback<Void>() { @Override public Void withHandle(final Handle handle) throws Exception { // Note: we always create an accounts table, see MysqlTestingHelper handle.execute("insert into tag_definitions (record_id, id, name, description, is_active, created_date, created_by, updated_date, updated_by, tenant_record_id) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)", tagDefinitionRecordId, tagDefinitionId.toString(), "tagdef", "nothing", true, new Date(), "i", new Date(), "j", 0); return null; } }); } private void insertTag() throws IOException { dbi.withHandle(new HandleCallback<Void>() { @Override public Void withHandle(final Handle handle) throws Exception { // Note: we always create an accounts table, see MysqlTestingHelper handle.execute("insert into tags (record_id, id, tag_definition_id, object_id, object_type, is_active, created_date, created_by, updated_date, updated_by, account_record_id, tenant_record_id) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)", tagRecordId, tagId.toString(), tagDefinitionId.toString(), accountId.toString(), "ACCOUNT", true, new Date(), "i", new Date(), "j", accountRecordId, 0); return null; } }); } private void insertTenant() throws IOException { dbi.withHandle(new HandleCallback<Void>() { @Override public Void withHandle(final Handle handle) throws Exception { // Note: we always create an accounts table, see MysqlTestingHelper handle.execute("insert into tenants (record_id, id, external_key, api_key, api_secret, api_salt, created_date, created_by, updated_date, updated_by) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)", tenantRecordId, tenantId.toString(), "foo", "key", "secret", "salt", new Date(), "i", new Date(), "j"); return null; } }); } }