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 expectedVerbs = asList("verb1", "verb2"); when(systemRepositoryPermissionProvider.availableVerbs()).thenReturn(expectedVerbs); Collection 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 actualRoles = repositoryPermissionProvider.availableRoles(); assertThat(actualRoles).containsExactly(systemRole, daoRole); } }