/** * Copyright 2014 Comcast Cable Communications Management, LLC * * This file is part of CATS. * * CATS is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * CATS is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with CATS. If not, see <http://www.gnu.org/licenses/>. */ package com.comcast.cats.domain.service.it; import java.util.List; import junit.framework.Assert; import org.junit.Test; import com.comcast.cats.domain.Rack; import com.comcast.cats.domain.SettopDesc; import com.comcast.cats.domain.User; import com.comcast.cats.domain.service.SettopDomainService; import com.comcast.cats.domain.test.DataProvider; /** * Integration Test cases for {@link Rack} name based search APIs in * {@link SettopDomainService}. * * <pre> * <b>Prerequisites:</b> * * 1. You should have a valid reservation in the configuration management system. * 2. You should have to provide the following properties in <b>/src/test/resources/test.props</b>. * * test.rack.name : A valid {@link Rack} name in the configuration management system. * test.offset : Offset * test.count : Count * * E.g. * test.rack.name = * test.offset = 0 * test.count = 1 * * 3. You should have cats.props file under $CATS_HOME directory with at least the following entries. * * cats.config.url : REST interface url of the configuration management system. * cats.user.authToken : Authentication token of the {@link User} in the configuration management system. * * E.g. * cats.config.url = http://192.168.160.201:8080/rest/cats/ * cats.user.authToken = 6551 * </pre> * * @author subinsugunan * */ public class SettopDomainServiceBasedOnRackNameIT extends BaseSettopDomainServiceIT { @Test( expected = IllegalArgumentException.class ) public void findAllByRackNull() { settopDomainService.findAllByRack( null ); } @Test( expected = IllegalArgumentException.class ) public void findAllByRackNameNull() { Rack rack = new Rack(); rack.setName( null ); settopDomainService.findAllByRack( rack ); } @Test( expected = IllegalArgumentException.class ) public void findAllByRackNameEmpty() { Rack rack = new Rack(); rack.setName( DataProvider.EMPTY_STRING ); settopDomainService.findAllByRack( rack ); } @Test public void findAllByInvalidRackName() { Rack rack = new Rack(); rack.setName( DataProvider.INVALID_NAME ); List< SettopDesc > settops = settopDomainService.findAllByRack( rack ); Assert.assertEquals( 0, settops.size() ); logResult( settops.size() ); } @Test public void findAllByRackName() { Rack rack = new Rack(); rack.setName( testProperties.getRackName() ); List< SettopDesc > settops = settopDomainService.findAllByRack( rack ); logResult( settops.size() ); } @Test public void findAlleByRackNameOffset() { Rack rack = new Rack(); rack.setName( testProperties.getRackName() ); count = 100; List< SettopDesc > settops = settopDomainService.findAllByRack( rack, offset, count ); logResult( settops.size() ); } @Test( expected = IllegalArgumentException.class ) public void findAvailableByRackNull() { settopDomainService.findAvailableByRack( null ); } @Test( expected = IllegalArgumentException.class ) public void findAvailableByRackNameNull() { Rack rack = new Rack(); rack.setName( null ); settopDomainService.findAvailableByRack( rack ); } @Test( expected = IllegalArgumentException.class ) public void findAvailableByRackNameEmpty() { Rack rack = new Rack(); rack.setName( DataProvider.EMPTY_STRING ); settopDomainService.findAvailableByRack( rack ); } @Test public void findAvailableByInvalidRackName() { Rack rack = new Rack(); rack.setName( DataProvider.INVALID_NAME ); List< SettopDesc > settops = settopDomainService.findAllByRack( rack ); Assert.assertEquals( 0, settops.size() ); logResult( settops.size() ); } @Test public void findAvailableByRackName() { Rack rack = new Rack(); rack.setName( testProperties.getRackName() ); List< SettopDesc > settops = settopDomainService.findAvailableByRack( rack ); logResult( settops.size() ); } @Test public void findAvailableByRackNameOffset() { Rack rack = new Rack(); rack.setName( testProperties.getRackName() ); count = 100; List< SettopDesc > settops = settopDomainService.findAvailableByRack( rack, offset, count ); logResult( settops.size() ); } }