blob: 0bcc0bdb4bd3606c8f80a92f9c8410332ceb47f7 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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
*
* https://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.apache.ivy.osgi.core;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;
import java.io.File;
import java.net.URL;
import java.util.Arrays;
import org.apache.ivy.core.module.descriptor.Configuration;
import org.apache.ivy.core.module.descriptor.ModuleDescriptor;
import org.apache.ivy.core.settings.IvySettings;
import org.apache.ivy.plugins.parser.AbstractModuleDescriptorParserTester;
import org.apache.ivy.plugins.parser.ParserSettings;
import org.apache.ivy.plugins.repository.Resource;
import org.apache.ivy.plugins.repository.file.FileResource;
import org.apache.ivy.util.DefaultMessageLogger;
import org.apache.ivy.util.Message;
import org.junit.Before;
import org.junit.Test;
public class OSGiManifestParserTest extends AbstractModuleDescriptorParserTester {
private IvySettings settings;
@Before
public void setUp() {
Message.setDefaultLogger(new DefaultMessageLogger(Message.MSG_WARN));
settings = new IvySettings();
// prevent test from polluting local cache
settings.setDefaultCache(new File("build/cache"));
}
@Test
public void testSimple() throws Exception {
ModuleDescriptor md = OSGiManifestParser.getInstance().parseDescriptor(settings,
getClass().getResource("MANIFEST_classpath.MF"), true);
assertNotNull(md);
assertEquals("bundle", md.getModuleRevisionId().getOrganisation());
assertEquals("org.apache.ivy.test", md.getModuleRevisionId().getName());
assertEquals("1.0.0", md.getModuleRevisionId().getRevision());
assertNotNull(md.getConfigurations());
assertEquals(Arrays.asList(new Configuration("default"),
new Configuration("optional"), new Configuration("transitive-optional")),
Arrays.asList(md.getConfigurations()));
assertEquals(0, md.getAllArtifacts().length);
assertNotNull(md.getDependencies());
assertEquals(0, md.getDependencies().length);
}
/**
* Tests that the
* {@link OSGiManifestParser#parseDescriptor(ParserSettings, URL, Resource, boolean)}
* works fine for descriptors that are backed by {@link FileResource}
*
* @throws Exception if something goes wrong
*/
@Test
public void testFileResource() throws Exception {
final File manifestFile = new File("test/repositories/osgi/module1/META-INF/MANIFEST.MF");
assertTrue("Manifest file is either missing or not a file at " + manifestFile.getAbsolutePath(), manifestFile.isFile());
final Resource manifestFileResource = new FileResource(null, manifestFile);
final ModuleDescriptor md = OSGiManifestParser.getInstance().parseDescriptor(settings, manifestFile.toURI().toURL(), manifestFileResource, true);
assertNotNull("Module descriptor created through a OSGi parser was null", md);
assertEquals("Unexpected organization name in module descriptor created through a OSGi parser", "bundle", md.getModuleRevisionId().getOrganisation());
assertEquals("Unexpected module name in module descriptor created through a OSGi parser", "module1", md.getModuleRevisionId().getName());
assertEquals("Unexpected version in module descriptor created through a OSGi parser", "1.2.3", md.getModuleRevisionId().getRevision());
}
}