/*
* Copyright 2016 Red Hat, Inc. and/or its affiliates.
*
* Licensed 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.
*/
package org.kie.workbench.common.screens.projecteditor.client.forms.repositories;
import java.util.HashSet;
import java.util.Set;
import org.guvnor.common.services.project.model.MavenRepositoryMetadata;
import org.guvnor.common.services.project.model.MavenRepositorySource;
import org.guvnor.common.services.project.model.ProjectRepositories;
import org.guvnor.common.services.shared.security.AppRoles;
import org.jboss.errai.security.shared.api.Role;
import org.jboss.errai.security.shared.api.RoleImpl;
import org.jboss.errai.security.shared.api.identity.User;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.runners.MockitoJUnitRunner;
import static org.mockito.Mockito.*;
@RunWith(MockitoJUnitRunner.class)
public class RepositoriesWidgetPresenterTest {
@Mock
private RepositoriesWidgetView view;
@Mock
private User identity;
private RepositoriesWidgetPresenter presenter;
private ProjectRepositories.ProjectRepository repository = new ProjectRepositories.ProjectRepository( true,
new MavenRepositoryMetadata( "id",
"url",
MavenRepositorySource.LOCAL ) );
private Set<ProjectRepositories.ProjectRepository> repositories;
@Before
public void setup() {
presenter = new RepositoriesWidgetPresenter( identity,
view );
repositories = new HashSet<ProjectRepositories.ProjectRepository>();
repositories.add( repository );
}
@Test
public void testSetContentNotReadOnlyNotAdminRole() {
when( identity.getRoles() ).thenReturn( new HashSet<Role>() {{
add( new RoleImpl( "user" ) );
}} );
presenter.setContent( repositories,
false );
verify( view,
times( 1 ) ).setContent( eq( repositories ),
eq( true ) );
}
@Test
public void testSetContentNotReadOnlyAdminRole() {
when( identity.getRoles() ).thenReturn( new HashSet<Role>() {{
add( new RoleImpl( AppRoles.ADMIN.getName() ) );
}} );
presenter.setContent( repositories,
false );
verify( view,
times( 1 ) ).setContent( eq( repositories ),
eq( false ) );
}
@Test
public void testSetContentReadOnlyNotAdminRole() {
when( identity.getRoles() ).thenReturn( new HashSet<Role>() {{
add( new RoleImpl( "user" ) );
}} );
presenter.setContent( repositories,
true );
verify( view,
times( 1 ) ).setContent( eq( repositories ),
eq( true ) );
}
@Test
public void testSetContentReadOnlyAdminRole() {
when( identity.getRoles() ).thenReturn( new HashSet<Role>() {{
add( new RoleImpl( AppRoles.ADMIN.getName() ) );
}} );
presenter.setContent( repositories,
true );
verify( view,
times( 1 ) ).setContent( eq( repositories ),
eq( true ) );
}
}