mirror of
https://github.com/opennetworkinglab/onos.git
synced 2025-10-21 20:31:00 +02:00
Minor formatting changes in unit test for component config loader
Change-Id: Ifa6e69d09d902d6c894fac4878a18b864c8ec4e3
This commit is contained in:
parent
99b7b34663
commit
33279c8f41
@ -41,8 +41,10 @@ import static org.slf4j.LoggerFactory.getLogger;
|
|||||||
@Component(immediate = true)
|
@Component(immediate = true)
|
||||||
public class ComponentConfigLoader {
|
public class ComponentConfigLoader {
|
||||||
|
|
||||||
private static final File CFG_FILE = new File("../config/component-cfg.json");
|
|
||||||
private static final int RETRY_DELAY = 5_000; // millis between retries
|
private static final int RETRY_DELAY = 5_000; // millis between retries
|
||||||
|
private static final String CFG_JSON = "../config/component-cfg.json";
|
||||||
|
|
||||||
|
static File cfgFile = new File(CFG_JSON);
|
||||||
|
|
||||||
private final Logger log = getLogger(getClass());
|
private final Logger log = getLogger(getClass());
|
||||||
|
|
||||||
@ -78,15 +80,15 @@ public class ComponentConfigLoader {
|
|||||||
*/
|
*/
|
||||||
private void loadConfigs() {
|
private void loadConfigs() {
|
||||||
try {
|
try {
|
||||||
if (CFG_FILE.exists()) {
|
if (cfgFile.exists()) {
|
||||||
root = (ObjectNode) new ObjectMapper().readTree(CFG_FILE);
|
root = (ObjectNode) new ObjectMapper().readTree(cfgFile);
|
||||||
root.fieldNames().forEachRemaining(pendingComponents::add);
|
root.fieldNames().forEachRemaining(pendingComponents::add);
|
||||||
SharedExecutors.getTimer().schedule(loader, RETRY_DELAY, RETRY_DELAY);
|
SharedExecutors.getTimer().schedule(loader, 0, RETRY_DELAY);
|
||||||
log.info("Loaded initial component configuration from {}", CFG_FILE);
|
log.info("Loaded initial component configuration from {}", cfgFile);
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.warn("Unable to load initial component configuration from {}",
|
log.warn("Unable to load initial component configuration from {}",
|
||||||
CFG_FILE, e);
|
cfgFile, e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
|
@ -0,0 +1,113 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2015 Open Networking Laboratory
|
||||||
|
*
|
||||||
|
* 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 org.onosproject.cfg.impl;
|
||||||
|
|
||||||
|
import com.google.common.collect.ImmutableSet;
|
||||||
|
import com.google.common.io.Files;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.onosproject.cfg.ComponentConfigAdapter;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
import static com.google.common.io.ByteStreams.toByteArray;
|
||||||
|
import static com.google.common.io.Files.write;
|
||||||
|
import static org.junit.Assert.assertEquals;
|
||||||
|
import static org.junit.Assert.assertNull;
|
||||||
|
import static org.onlab.junit.TestTools.assertAfter;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* UnitTest for ComponentLoader.
|
||||||
|
*/
|
||||||
|
public class ComponentConfigLoaderTest {
|
||||||
|
|
||||||
|
static final File TEST_DIR = Files.createTempDir();
|
||||||
|
|
||||||
|
private static final String FOO_COMPONENT = "fooComponent";
|
||||||
|
|
||||||
|
private ComponentConfigLoader loader;
|
||||||
|
|
||||||
|
private TestConfigService service;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Method to SetUp the test environment with test file, a config loader a service,
|
||||||
|
* and assign it to the loader.configService for the test.
|
||||||
|
*/
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
ComponentConfigLoader.cfgFile = new File(TEST_DIR, "test.json");
|
||||||
|
loader = new ComponentConfigLoader();
|
||||||
|
service = new TestConfigService();
|
||||||
|
loader.configService = service;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Tests that the component in the json receives the correct configuration.
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void basics() throws IOException {
|
||||||
|
stageTestResource("basic.json");
|
||||||
|
loader.activate();
|
||||||
|
assertAfter(1_000, () -> assertEquals("incorrect component", FOO_COMPONENT, service.component));
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Tests that the component is null if the file has a bad configuration format
|
||||||
|
* for which it yielded an exception. Can't test the exception because it happens
|
||||||
|
* in a different thread,
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void badConfig() throws IOException {
|
||||||
|
stageTestResource("badConfig.json");
|
||||||
|
loader.activate();
|
||||||
|
assertAfter(1_000, () -> assertNull("incorrect component", service.component));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Writes the necessary file for the tests in the temporary directory
|
||||||
|
*/
|
||||||
|
static void stageTestResource(String name) throws IOException {
|
||||||
|
byte[] bytes = toByteArray(ComponentConfigLoaderTest.class.getResourceAsStream(name));
|
||||||
|
write(bytes, ComponentConfigLoader.cfgFile);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Mockup class for the config service.
|
||||||
|
*/
|
||||||
|
private class TestConfigService extends ComponentConfigAdapter {
|
||||||
|
|
||||||
|
private String component;
|
||||||
|
private String name;
|
||||||
|
private String value;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Set<String> getComponentNames() {
|
||||||
|
return ImmutableSet.of(FOO_COMPONENT);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setProperty(String componentName, String name, String value) {
|
||||||
|
this.component = componentName;
|
||||||
|
this.name = name;
|
||||||
|
this.value = value;
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,5 @@
|
|||||||
|
{
|
||||||
|
"fooComponent": {
|
||||||
|
badconfig
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,5 @@
|
|||||||
|
{
|
||||||
|
"fooComponent": {
|
||||||
|
"testProperty": true
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user