mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-13 00:45:44 +01:00
Join repository roles from the system and from the database
This commit is contained in:
@@ -0,0 +1,51 @@
|
||||
package sonia.scm.security;
|
||||
|
||||
import org.junit.jupiter.api.Test;
|
||||
import org.junit.jupiter.api.extension.ExtendWith;
|
||||
import org.mockito.InjectMocks;
|
||||
import org.mockito.Mock;
|
||||
import org.mockito.junit.jupiter.MockitoExtension;
|
||||
import sonia.scm.repository.RepositoryRole;
|
||||
import sonia.scm.repository.RepositoryRoleDAO;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
|
||||
import static java.util.Arrays.asList;
|
||||
import static java.util.Collections.singletonList;
|
||||
import static org.assertj.core.api.Assertions.assertThat;
|
||||
import static org.mockito.Mockito.when;
|
||||
|
||||
@ExtendWith(MockitoExtension.class)
|
||||
class RepositoryPermissionProviderTest {
|
||||
|
||||
@Mock
|
||||
SystemRepositoryPermissionProvider systemRepositoryPermissionProvider;
|
||||
@Mock
|
||||
RepositoryRoleDAO repositoryRoleDAO;
|
||||
|
||||
@InjectMocks
|
||||
RepositoryPermissionProvider repositoryPermissionProvider;
|
||||
|
||||
@Test
|
||||
void shouldReturnVerbsFromSystem() {
|
||||
List<String> expectedVerbs = asList("verb1", "verb2");
|
||||
when(systemRepositoryPermissionProvider.availableVerbs()).thenReturn(expectedVerbs);
|
||||
|
||||
Collection<String> actualVerbs = repositoryPermissionProvider.availableVerbs();
|
||||
|
||||
assertThat(actualVerbs).isEqualTo(expectedVerbs);
|
||||
}
|
||||
|
||||
@Test
|
||||
void shouldReturnJoinedRolesFromSystemAndDao() {
|
||||
RepositoryRole systemRole = new RepositoryRole("roleSystem", singletonList("verb1"), "system");
|
||||
RepositoryRole daoRole = new RepositoryRole("roleDao", singletonList("verb1"), "xml");
|
||||
when(systemRepositoryPermissionProvider.availableRoles()).thenReturn(singletonList(systemRole));
|
||||
when(repositoryRoleDAO.getAll()).thenReturn(singletonList(daoRole));
|
||||
|
||||
Collection<RepositoryRole> actualRoles = repositoryPermissionProvider.availableRoles();
|
||||
|
||||
assertThat(actualRoles).containsExactly(systemRole, daoRole);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user