X-Git-Url: https://gerrit.onap.org/r/gitweb?a=blobdiff_plain;f=src%2Ftest%2Fjava%2Forg%2Fonap%2Faai%2Fmodelloader%2Ffixture%2FArtifactInfoBuilder.java;fp=src%2Ftest%2Fjava%2Forg%2Fonap%2Faai%2Fmodelloader%2Ffixture%2FArtifactInfoBuilder.java;h=2540865e44e2f6270e0e2e64388bd9eb1671995d;hb=7b1f813441f94261f43ec4f5bb0944ad2570fbdf;hp=0000000000000000000000000000000000000000;hpb=4dd316529148d07059d844197cdb676806bdc0c6;p=aai%2Fmodel-loader.git diff --git a/src/test/java/org/onap/aai/modelloader/fixture/ArtifactInfoBuilder.java b/src/test/java/org/onap/aai/modelloader/fixture/ArtifactInfoBuilder.java new file mode 100644 index 0000000..2540865 --- /dev/null +++ b/src/test/java/org/onap/aai/modelloader/fixture/ArtifactInfoBuilder.java @@ -0,0 +1,78 @@ +/** + * ============LICENSE_START========================================== + * org.onap.aai + * =================================================================== + * Copyright © 2017-2018 AT&T Intellectual Property. All rights reserved. + * Copyright © 2017-2018 Amdocs + * =================================================================== + * 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. + * ============LICENSE_END============================================ + */ +package org.onap.aai.modelloader.fixture; + +import java.util.ArrayList; +import java.util.List; + +import org.onap.aai.modelloader.service.ArtifactInfoImpl; +import org.openecomp.sdc.api.notification.IArtifactInfo; + +/** + * This class builds an instance of IArtifactInfo for test purposes. + */ +public class ArtifactInfoBuilder { + + /** + * Builds an implementation of IArtifactInfo for test purposes. + *

+ * + * @param type type of artifact + * @param name name of artifact + * @param description description of artifact + * @param version version of artifact + * @return IArtifactInfo implementation of IArtifactInfo from given parameters for test purposes + */ + public static IArtifactInfo build(final String type, final String name, final String description, + final String version) { + IArtifactInfo artifact = new ArtifactInfoImpl(); + + ((ArtifactInfoImpl) artifact).setArtifactType(type); + ((ArtifactInfoImpl) artifact).setArtifactName(name); + ((ArtifactInfoImpl) artifact).setArtifactDescription(description); + ((ArtifactInfoImpl) artifact).setArtifactVersion(version); + + return artifact; + } + + /** + * This method is responsible for building a collection of artifacts from a given set of info. + *

+ * The info supplied is a two dimensional array with each element of the first dimension representing a single + * artifact and each element of the second dimension represents a property of the artifact. + *

+ * The method will call {@link #build(String, String, String, String)} to build each element in the first dimension + * where the elements of the second dimension are the arguments to {@link #build(String, String, String, String)}. + *

+ * + * @param artifactInfoBits a two dimensional array of data used to build the artifacts + * @return List a list of artifacts built from the given array of info + */ + static List buildArtifacts(final String[][] artifactInfoBits) { + List artifacts = new ArrayList<>(); + + for (String[] artifactInfoBit : artifactInfoBits) { + artifacts.add(build(artifactInfoBit[0], artifactInfoBit[1], artifactInfoBit[2], artifactInfoBit[3])); + } + + return artifacts; + } +}