aboutsummaryrefslogtreecommitdiffstats
path: root/catalog-fe/src/test/java/org/openecomp/sdc/fe/impl/AuditTest.java
blob: c65d75bdab34aa68a132d87e796ccc91f2aca981 (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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
/*-
 * ============LICENSE_START=======================================================
 * SDC
 * ================================================================================
 * Copyright (C) 2019 Samsung. 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.openecomp.sdc.fe.impl;

import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.junit.MockitoJUnitRunner;
import org.openecomp.sdc.common.api.Constants;
import org.slf4j.Logger;

import javax.servlet.http.HttpServletRequest;
import java.util.HashMap;
import java.util.Map;

import static org.mockito.ArgumentMatchers.eq;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;

@RunWith(MockitoJUnitRunner.class)
public class AuditTest {

    private static final int STATUS = 12345;
    private static final String[] PARAMETERS = {"abc", "def", "ghi", "jkl", "mno", "http"};
    private static final String EXPECTED = "EVENT = ARTIFACT_UPLOAD  USER_ID=abc USER_NAME=def ghi ACCESS_IP=jkl ACCESS_TYPE=mno RURL=http SC=12345";
    private static final String INTERNAL_ERROR = "Internal Error";

    @Mock
    private Logger log;

    @Mock
    private HttpRequestInfo info;

    @Mock
    private HttpServletRequest request;

    @Test
    public void testErrorWithEmptyHttpRequestInfo() {
        // when
        Audit.error(log, (HttpRequestInfo) null, 0);

        // then
        verify(log).error(eq(INTERNAL_ERROR));
    }

    @Test
    public void testErrorWithHttpRequestInfo() {
        // given
        Map<String, String> headers = new HashMap<>();
        headers.put(Constants.USER_ID_HEADER, PARAMETERS[0]);
        headers.put(Constants.FIRST_NAME_HEADER, PARAMETERS[1]);
        headers.put(Constants.LAST_NAME_HEADER, PARAMETERS[2]);
        headers.put(Constants.ORIGIN_HEADER, PARAMETERS[3]);
        headers.put(Constants.ACCESS_HEADER, PARAMETERS[4]);

        when(info.getHeaders()).thenReturn(headers);
        when(info.getRequestURL()).thenReturn(PARAMETERS[5]);

        // when
        Audit.error(log, info, STATUS);

        // then
        verify(log).error(eq(EXPECTED));
    }

    @Test
    public void testErrorWithEmptyHttpServletRequest() {
        // when
        Audit.error(log, (HttpServletRequest) null, 0);

        // then
        verify(log).error(eq(INTERNAL_ERROR));
    }

    @Test
    public void testErrorWithHttpServletRequest() {
        // given
        when(request.getHeader(Constants.USER_ID_HEADER)).thenReturn(PARAMETERS[0]);
        when(request.getHeader(Constants.FIRST_NAME_HEADER)).thenReturn(PARAMETERS[1]);
        when(request.getHeader(Constants.LAST_NAME_HEADER)).thenReturn(PARAMETERS[2]);
        when(request.getHeader(Constants.ORIGIN_HEADER)).thenReturn(PARAMETERS[3]);
        when(request.getHeader(Constants.ACCESS_HEADER)).thenReturn(PARAMETERS[4]);
        when(request.getRequestURL()).thenReturn(new StringBuffer(PARAMETERS[5]));

        // when
        Audit.error(log, request, STATUS);

        // then
        verify(log).error(eq(EXPECTED));
    }

    @Test
    public void testInfoWithEmptyHttpRequestInfo() {
        // when
        Audit.info(log, null, 0);

        // then
        verify(log).info(eq(INTERNAL_ERROR));
    }

    @Test
    public void testInfoWithHttpRequestInfo() {
        // given
        Map<String, String> headers = new HashMap<>();
        headers.put(Constants.USER_ID_HEADER, PARAMETERS[0]);
        headers.put(Constants.FIRST_NAME_HEADER, PARAMETERS[1]);
        headers.put(Constants.LAST_NAME_HEADER, PARAMETERS[2]);
        headers.put(Constants.ORIGIN_HEADER, PARAMETERS[3]);
        headers.put(Constants.ACCESS_HEADER, PARAMETERS[4]);

        when(info.getHeaders()).thenReturn(headers);
        when(info.getRequestURL()).thenReturn(PARAMETERS[5]);

        // when
        Audit.info(log, info, STATUS);

        // then
        verify(log).info(eq(EXPECTED));
    }
}