123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- package org.apache.archiva.metadata.repository.cassandra;
-
- /*
- * 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
- *
- * 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.
- */
-
- import org.apache.archiva.metadata.model.ProjectMetadata;
- import org.apache.archiva.metadata.repository.cassandra.model.Namespace;
- import org.apache.archiva.metadata.repository.cassandra.model.Repository;
- import org.junit.jupiter.api.AfterAll;
- import org.junit.jupiter.api.AfterEach;
- import org.junit.jupiter.api.BeforeAll;
- import org.junit.jupiter.api.BeforeEach;
- import org.junit.jupiter.api.Test;
- import org.junit.jupiter.api.extension.ExtendWith;
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- import org.springframework.test.context.ContextConfiguration;
- import org.springframework.test.context.junit.jupiter.SpringExtension;
- import org.testcontainers.containers.CassandraContainer;
- import org.testcontainers.containers.output.Slf4jLogConsumer;
- import org.testcontainers.utility.DockerImageName;
-
- import javax.inject.Inject;
- import javax.inject.Named;
-
- import static org.assertj.core.api.Assertions.assertThat;
-
- /**
- * @author Olivier Lamy
- */
- @ExtendWith( SpringExtension.class )
- @ContextConfiguration( locations = { "classpath*:/META-INF/spring-context.xml" } )
- public class RepositoriesNamespaceTest
- {
-
- private static final Logger LOGGER = LoggerFactory.getLogger( RepositoriesNamespaceTest.class );
-
- private static final CassandraContainer CASSANDRA =
- new CassandraContainer(DockerImageName.parse("cassandra")
- .withTag(System.getProperty("cassandraVersion","3.11.2")));
-
- @Inject
- @Named( value = "archivaEntityManagerFactory#cassandra" )
- CassandraArchivaManager cassandraArchivaManager;
-
- CassandraMetadataRepository cmr;
-
- @BeforeAll
- public static void initCassandra()
- throws Exception {
- CASSANDRA.withLogConsumer(new Slf4jLogConsumer(LoggerFactory.getLogger("org.apache.archiva.metadata.repository.cassandra.logs")));
- CASSANDRA.start();
- System.setProperty("cassandra.host", CASSANDRA.getHost());
- System.setProperty("cassandra.port", CASSANDRA.getMappedPort(9042).toString());
- }
-
- @AfterAll
- public static void stopCassandra()
- throws Exception {
- CASSANDRA.close();
- }
-
- @BeforeEach
- public void setup()
- throws Exception
- {
- cmr = new CassandraMetadataRepository( null, cassandraArchivaManager );
- if ( !cassandraArchivaManager.started() )
- {
- cassandraArchivaManager.start();
- }
- CassandraMetadataRepositoryTest.clearReposAndNamespace( cassandraArchivaManager );
- }
-
- @AfterEach
- public void shutdown()
- throws Exception
- {
- CassandraMetadataRepositoryTest.clearReposAndNamespace( cassandraArchivaManager );
- cassandraArchivaManager.shutdown();
- }
-
-
- @Test
- public void testMetadataRepo()
- throws Exception
- {
-
- Repository r = null;
- Namespace n = null;
-
- try
- {
-
- cmr.updateNamespace( null , "release", "org" );
-
- r = cmr.getRepository( "release" );
-
- assertThat( r ).isNotNull();
-
- assertThat( cmr.getNamespaces( "release" ) ).isNotEmpty().hasSize( 1 );
-
- n = cmr.getNamespace( "release", "org" );
-
- assertThat( n ).isNotNull();
- assertThat( n.getRepository() ).isNotNull();
-
- cmr.updateNamespace( null, "release", "org.apache" );
-
- r = cmr.getRepository( "release" );
-
- assertThat( r ).isNotNull();
- assertThat( cmr.getNamespaces( "release" ) ).isNotEmpty().hasSize( 2 );
-
- cmr.removeNamespace(null , "release", "org.apache" );
- assertThat( cmr.getNamespaces( "release" ) ).isNotEmpty().hasSize( 1 );
- assertThat( cmr.getNamespaces( "release" ) ).containsExactly( "org" );
-
- ProjectMetadata projectMetadata = new ProjectMetadata();
- projectMetadata.setId( "theproject" );
- projectMetadata.setNamespace( "org" );
-
- cmr.updateProject(null , "release", projectMetadata );
-
- assertThat( cmr.getProjects(null , "release", "org" ) ).isNotEmpty().hasSize( 1 ).containsExactly(
- "theproject" );
-
- cmr.removeProject(null , "release", "org", "theproject" );
-
- assertThat( cmr.getProjects(null , "release", "org" ) ).isEmpty();
-
- cmr.removeRepository(null , "release" );
-
- r = cmr.getRepository( "release" );
-
- assertThat( r ).isNull();
-
- }
- catch ( Exception e )
- {
- LOGGER.error( e.getMessage(), e );
- throw e;
- }
- finally
- {
- CassandraMetadataRepositoryTest.clearReposAndNamespace( cassandraArchivaManager );
- }
- }
- }
|