From 597192ba5b041b29dc68e0181e13648f2cdcbb36 Mon Sep 17 00:00:00 2001 From: rreich Date: Mon, 28 Sep 2020 21:15:03 +0200 Subject: [PATCH] Make DefaultPluginDescriptor#addDependency usable (#398) Thanks! --- .../org/pf4j/DefaultPluginDescriptor.java | 13 ++---- .../org/pf4j/DefaultPluginDescriptorTest.java | 42 +++++++++++++++++++ 2 files changed, 45 insertions(+), 10 deletions(-) create mode 100644 pf4j/src/test/java/org/pf4j/DefaultPluginDescriptorTest.java diff --git a/pf4j/src/main/java/org/pf4j/DefaultPluginDescriptor.java b/pf4j/src/main/java/org/pf4j/DefaultPluginDescriptor.java index 5903662..bd6b297 100644 --- a/pf4j/src/main/java/org/pf4j/DefaultPluginDescriptor.java +++ b/pf4j/src/main/java/org/pf4j/DefaultPluginDescriptor.java @@ -16,7 +16,6 @@ package org.pf4j; import java.util.ArrayList; -import java.util.Collections; import java.util.List; import java.util.Objects; @@ -167,12 +166,11 @@ public class DefaultPluginDescriptor implements PluginDescriptor { } protected PluginDescriptor setDependencies(String dependencies) { + this.dependencies = new ArrayList<>(); + if (dependencies != null) { dependencies = dependencies.trim(); - if (dependencies.isEmpty()) { - this.dependencies = Collections.emptyList(); - } else { - this.dependencies = new ArrayList<>(); + if (!dependencies.isEmpty()) { String[] tokens = dependencies.split(","); for (String dependency : tokens) { dependency = dependency.trim(); @@ -180,12 +178,7 @@ public class DefaultPluginDescriptor implements PluginDescriptor { this.dependencies.add(new PluginDependency(dependency)); } } - if (this.dependencies.isEmpty()) { - this.dependencies = Collections.emptyList(); - } } - } else { - this.dependencies = Collections.emptyList(); } return this; diff --git a/pf4j/src/test/java/org/pf4j/DefaultPluginDescriptorTest.java b/pf4j/src/test/java/org/pf4j/DefaultPluginDescriptorTest.java new file mode 100644 index 0000000..0cbbad6 --- /dev/null +++ b/pf4j/src/test/java/org/pf4j/DefaultPluginDescriptorTest.java @@ -0,0 +1,42 @@ +/* + * Copyright (C) 2012-present the original author or authors. + * + * 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.pf4j; + +import org.junit.jupiter.api.Test; + +import java.util.ArrayList; +import java.util.List; + +import static org.junit.jupiter.api.Assertions.assertEquals; + +class DefaultPluginDescriptorTest { + + @Test + void addDependency() { + // Given a descriptor with empty dependencies + DefaultPluginDescriptor descriptor = new DefaultPluginDescriptor(); + descriptor.setDependencies(""); + PluginDependency newDependency = new PluginDependency("test"); + + // When I add a dependency + descriptor.addDependency(newDependency); + + // Then the dependency is added + List expected = new ArrayList<>(); + expected.add(newDependency); + assertEquals(expected, descriptor.getDependencies()); + } +} -- 2.39.5