summaryrefslogtreecommitdiffstats
path: root/src/test/java/org/onap/dmaap/commonauth/kafka/base/authorization/Cadi3AAFProviderTest.java
blob: 1a2bd95cc47039f85ebed23aec45a8258d35e1a1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
/*******************************************************************************
 *  ============LICENSE_START=======================================================
 *  org.onap.dmaap
 *  ================================================================================
 *  Copyright © 2017 AT&T Intellectual Property. All rights reserved.
 *  ================================================================================
 *  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.
 *  ============LICENSE_END=========================================================
 *  
 *  
 *******************************************************************************/
package org.onap.dmaap.commonauth.kafka.base.authorization;

import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertNull;
import static org.mockito.Mockito.when;

import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.MockitoAnnotations;
import org.onap.aaf.cadi.PropAccess;
import org.onap.aaf.cadi.aaf.AAFPermission;
import org.onap.aaf.cadi.aaf.v2_0.AAFAuthn;
import org.onap.aaf.cadi.aaf.v2_0.AAFConHttp;
import org.onap.aaf.cadi.aaf.v2_0.AbsAAFLur;
import org.powermock.core.classloader.annotations.PowerMockIgnore;
import org.powermock.modules.junit4.PowerMockRunner;


@RunWith(PowerMockRunner.class)
@PowerMockIgnore({"javax.net.ssl.*", "javax.security.auth.*", "jdk.internal.reflect.*"})
public class Cadi3AAFProviderTest {

	public Cadi3AAFProvider cadi3AAFProvider;

	@Mock
	private static AAFAuthn<?> aafAuthn;
	
	@Mock
	private static AAFConHttp aafCon;
	
	@Mock
	private static AbsAAFLur<AAFPermission> aafLur;

	@Mock
	private static PropAccess access;

	@Before
	public void setUp() throws Exception {
		MockitoAnnotations.initMocks(this);
		System.setProperty("enableCadi", "true");
		System.setProperty("CADI_PROPERTIES", "src/test/resources/cadi.properties");
		cadi3AAFProvider = new Cadi3AAFProvider();
	}

	@Test
	public void testHasPermission() {
		assertFalse(cadi3AAFProvider.hasPermission("userID", "permission", "instance", "action"));
	}

	@Test
	public void testHasAdminPermission() {
		assertEquals(cadi3AAFProvider.hasPermission("admin", "permission", "instance", "action"), true);
	}
	
	@Test(expected = NullPointerException.class)
	public void tesAuthenticate() throws Exception {
		System.setProperty("enableCadi", "true");
		when(aafAuthn.validate("userId", "password")).thenReturn("valid");
		assertEquals(cadi3AAFProvider.authenticate("userId", "password"), "valid");
	}

	@Test
	public void tesAuthenticateAdmin() throws Exception {
		assertNull(cadi3AAFProvider.authenticate("kafkaUsername", "apiKey"));
	}
	
	@Test
	public void tesAuthenticateAdminwtWrongCred() throws Exception {
		assertNotNull(cadi3AAFProvider.authenticate("kafkaUsername", "api"));
	}
	
}