blob: c3693cb8318fba1211905c50bbbc757a017a5b1f [file] [log] [blame]
/*
* Copyright 2015-present Open Networking Foundation
*
* 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.
*
* Originally created by Pengfei Lu, Network and Cloud Computing Laboratory, Dalian University of Technology, China
* Advisers: Keqiu Li and Heng Qi
* This work is supported by the State Key Program of National Natural Science of China(Grant No. 61432002)
* and Prospective Research Project on Future Networks in Jiangsu Future Networks Innovation Institute.
*/
package org.onosproject.acl;
import org.glassfish.jersey.server.ResourceConfig;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.onlab.junit.TestUtils;
import org.onlab.osgi.ServiceDirectory;
import org.onlab.osgi.TestServiceDirectory;
import org.onlab.rest.BaseResource;
import org.onosproject.core.IdGenerator;
import org.onosproject.rest.resources.ResourceTest;
import javax.ws.rs.client.Entity;
import javax.ws.rs.client.WebTarget;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.atomic.AtomicLong;
import static org.easymock.EasyMock.*;
import static org.hamcrest.Matchers.containsString;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertThat;
/**
* Test class for ACL application REST resource.
*/
public class AclWebResourceTest extends ResourceTest {
final AclService mockAclService = createMock(AclService.class);
final AclStore mockAclStore = createMock(AclStore.class);
final List<AclRule> rules = new ArrayList<>();
/**
* Constructs a control metrics collector resource test instance.
*/
public AclWebResourceTest() {
super(ResourceConfig.forApplicationClass(AclWebApplication.class));
}
@Before
public void setUpMock() {
expect(mockAclService.getAclRules()).andReturn(rules).anyTimes();
ServiceDirectory testDirectory = new TestServiceDirectory()
.add(AclService.class, mockAclService)
.add(AclStore.class, mockAclStore);
setServiceDirectory(testDirectory);
TestUtils.setField(BaseResource.class, "services", testDirectory);
AclRule.idGenerator = new MockIdGenerator();
}
@After
public void tearDown() {
verify(mockAclService);
}
/**
* Mock id generator for testing.
*/
private class MockIdGenerator implements IdGenerator {
private AtomicLong nextId = new AtomicLong(0);
@Override
public long getNewId() {
return nextId.getAndIncrement();
}
}
@Test
public void addInvalidRule() {
WebTarget wt = target();
String response;
InputStream jsonStream;
replay(mockAclService);
// input a invalid JSON string that contains neither nw_src and nw_dst
jsonStream = AclWebResourceTest.class
.getResourceAsStream("post-invalid-acl.json");
response = wt.path("rules").request(MediaType.APPLICATION_JSON_TYPE)
.post(Entity.json(jsonStream), String.class);
assertThat(response.toString(), containsString("Either srcIp or dstIp must be assigned."));
// input a invalid JSON string that doesn't contain CIDR mask bits
jsonStream = AclWebResourceTest.class
.getResourceAsStream("post-invalid-ip-1.json");
response = wt.path("rules").request(MediaType.APPLICATION_JSON_TYPE)
.post(Entity.json(jsonStream), String.class);
assertThat(response, containsString("Malformed IPv4 prefix string: 10.0.0.1. " +
"Address must take form \"x.x.x.x/y\""));
// input a invalid JSON string that contains a invalid IP address
jsonStream = AclWebResourceTest.class
.getResourceAsStream("post-invalid-ip-2.json");
response = wt.path("rules").request(MediaType.APPLICATION_JSON_TYPE)
.post(Entity.json(jsonStream), String.class);
assertThat(response, containsString("Invalid IP address string: 10.0.0.256"));
// input a invalid JSON string that contains a invalid IP address
jsonStream = AclWebResourceTest.class
.getResourceAsStream("post-invalid-ip-3.json");
response = wt.path("rules").request(MediaType.APPLICATION_JSON_TYPE)
.post(Entity.json(jsonStream), String.class);
assertThat(response, containsString("Invalid IP address string: 10.0.01"));
// input a invalid JSON string that contains a invalid CIDR mask bits
jsonStream = AclWebResourceTest.class
.getResourceAsStream("post-invalid-cidr-1.json");
response = wt.path("rules").request(MediaType.APPLICATION_JSON_TYPE)
.post(Entity.json(jsonStream), String.class);
assertThat(response, containsString("For input string: \"a\""));
// input a invalid JSON string that contains a invalid CIDR mask bits
jsonStream = AclWebResourceTest.class
.getResourceAsStream("post-invalid-cidr-2.json");
response = wt.path("rules").request(MediaType.APPLICATION_JSON_TYPE)
.post(Entity.json(jsonStream), String.class);
assertThat(response, containsString("Invalid prefix length 33. The value must be in the interval [0, 32]"));
// input a invalid JSON string that contains a invalid ipProto value
jsonStream = AclWebResourceTest.class
.getResourceAsStream("post-invalid-proto.json");
response = wt.path("rules").request(MediaType.APPLICATION_JSON_TYPE)
.post(Entity.json(jsonStream), String.class);
assertThat(response, containsString("ipProto must be assigned to TCP, UDP, or ICMP"));
// input a invalid JSON string that contains a invalid action value
jsonStream = AclWebResourceTest.class
.getResourceAsStream("post-invalid-action.json");
response = wt.path("rules").request(MediaType.APPLICATION_JSON_TYPE)
.post(Entity.json(jsonStream), String.class);
assertThat(response, containsString("action must be ALLOW or DENY"));
}
@Test
public void addRule() {
mockAclService.addAclRule(anyObject());
expectLastCall().andReturn(true).anyTimes();
replay(mockAclService);
WebTarget wt = target();
InputStream jsonStream;
jsonStream = AclWebResourceTest.class
.getResourceAsStream("post-valid-acl.json");
Response response = wt.path("rules").request(MediaType.APPLICATION_JSON_TYPE)
.post(Entity.json(jsonStream));
assertEquals(response.getLocation().getPath(), "/0x0");
}
}