Files
SCM-Manager/scm-webapp/src/test/java/sonia/scm/security/RepositoryPermissionProviderTest.java

52 lines
1.7 KiB
Java

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);
}
}