2 * Copyright (c) 2015 CableLabs and others. All rights reserved.
4 * This program and the accompanying materials are made available under the
5 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6 * and is available at http://www.eclipse.org/legal/epl-v10.html
9 package org.opendaylight.controller.packetcable.provider.validation.impl.validators.qos;
11 import org.junit.Rule;
12 import org.junit.Test;
13 import org.opendaylight.controller.packetcable.provider.test.rules.Params;
14 import org.opendaylight.controller.packetcable.provider.validation.ValidationException;
15 import org.opendaylight.controller.packetcable.provider.validation.Validator;
16 import org.opendaylight.yang.gen.v1.urn.packetcable.rev161107.pcmm.qos.gates.apps.App;
17 import org.opendaylight.yang.gen.v1.urn.packetcable.rev161107.pcmm.qos.gates.apps.AppBuilder;
22 @Params.AlwaysUseParams
23 public class AppValidatorTest {
26 public Params<Validator.Extent> extentParams = Params.of(Validator.Extent.class);
28 private final AppValidator validator = new AppValidator();
30 @Test(expected = ValidationException.class)
31 public void nullSubscribers() throws ValidationException {
32 validator.validate(null, extentParams.getCurrentParam());
35 @Params.DoNotUseParams
36 @Test(expected = NullPointerException.class)
37 public void nullExtent() throws ValidationException {
38 validator.validate(buildValidApp(), null);
41 @Test(expected = ValidationException.class)
42 public void nullAppId() throws ValidationException {
43 final App app = new AppBuilder(buildValidApp())
44 .setAppId(null).setKey(null)
47 validator.validate(app, extentParams.getCurrentParam());
51 public void valid() throws ValidationException {
52 validator.validate(buildValidApp(), extentParams.getCurrentParam());
55 public static App buildValidApp() {
56 return new AppBuilder()
57 .setAppId("unit-test-app")
58 .setSubscribers(SubscribersValidatorTest.buildValidSubscriber())