/* * Copyright 2013 uaiHebert Solucoes em Informatica * * 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 com.uaihebert.test.uaicriteria.multiselect; import com.uaihebert.model.test.RegularEntityOne; import com.uaihebert.test.MultiSelectAbstractTest; import com.uaihebert.uaicriteria.UaiCriteria; import org.junit.Test; public class ModuleMultiSelectTest extends MultiSelectAbstractTest { @Test public void isMethodInvokedWithTwoParameters() { if (isBatoo()) { return; } final String query = "select r.id, mod(r.id, r.integerAttributeOne) from RegularEntityOne r"; final UaiCriteria<RegularEntityOne> uaiCriteria = createMultiSelectCriteria(RegularEntityOne.class); uaiCriteria.addMultiSelectAttribute("id").module("id", "integerAttributeOne"); if (isEclipselink()) { validateResultWithVector(query, uaiCriteria); return; } validateResultAsList(query, uaiCriteria); } @Test public void isMultiSelectWorkingWithSeveralAttributesAndFunction() { if (isBatoo()) { return; } final String query = "select r.id, mod(r.id, r.integerAttributeOne), r.stringAttribute, r.floatAttributeOne, " + "r.dateAttributeTwo from RegularEntityOne r "; final UaiCriteria<RegularEntityOne> uaiCriteria = createMultiSelectCriteria(RegularEntityOne.class); uaiCriteria.addMultiSelectAttribute("id") .module("id", "integerAttributeOne") .addMultiSelectAttribute("stringAttribute") .addMultiSelectAttribute("floatAttributeOne") .addMultiSelectAttribute("dateAttributeTwo"); if (isEclipselink()) { validateResultWithVector(query, uaiCriteria); return; } validateResultAsList(query, uaiCriteria); } @Test public void isDiffNumberFromAttribute() { if (isBatoo()) { return; } final String query = "select r.id, mod(r.id, 10), r.stringAttribute, r.floatAttributeOne, " + "r.dateAttributeTwo from RegularEntityOne r "; final UaiCriteria<RegularEntityOne> uaiCriteria = createMultiSelectCriteria(RegularEntityOne.class); uaiCriteria.addMultiSelectAttribute("id") .module("id", 10) .addMultiSelectAttribute("stringAttribute", "floatAttributeOne") .addMultiSelectAttribute("dateAttributeTwo"); if (isEclipselink()) { validateResultWithVector(query, uaiCriteria); return; } validateResultAsList(query, uaiCriteria); } @Test public void isDiffAttributeFromNumber() { if (isBatoo()) { return; } final String query = "select r.id, mod(10, r.id), r.stringAttribute, r.floatAttributeOne, " + "r.dateAttributeTwo from RegularEntityOne r "; final UaiCriteria<RegularEntityOne> uaiCriteria = createMultiSelectCriteria(RegularEntityOne.class); uaiCriteria.addMultiSelectAttribute("id") .module(10, "id") .addMultiSelectAttribute("stringAttribute", "floatAttributeOne") .addMultiSelectAttribute("dateAttributeTwo"); if (isEclipselink()) { validateResultWithVector(query, uaiCriteria); return; } validateResultAsList(query, uaiCriteria); } }