mirror of
https://github.com/opennetworkinglab/onos.git
synced 2025-10-21 12:22:18 +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)
|
||||
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 String CFG_JSON = "../config/component-cfg.json";
|
||||
|
||||
static File cfgFile = new File(CFG_JSON);
|
||||
|
||||
private final Logger log = getLogger(getClass());
|
||||
|
||||
@ -78,15 +80,15 @@ public class ComponentConfigLoader {
|
||||
*/
|
||||
private void loadConfigs() {
|
||||
try {
|
||||
if (CFG_FILE.exists()) {
|
||||
root = (ObjectNode) new ObjectMapper().readTree(CFG_FILE);
|
||||
if (cfgFile.exists()) {
|
||||
root = (ObjectNode) new ObjectMapper().readTree(cfgFile);
|
||||
root.fieldNames().forEachRemaining(pendingComponents::add);
|
||||
SharedExecutors.getTimer().schedule(loader, RETRY_DELAY, RETRY_DELAY);
|
||||
log.info("Loaded initial component configuration from {}", CFG_FILE);
|
||||
SharedExecutors.getTimer().schedule(loader, 0, RETRY_DELAY);
|
||||
log.info("Loaded initial component configuration from {}", cfgFile);
|
||||
}
|
||||
} catch (Exception e) {
|
||||
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