Merge "Add monitor web page to Health Check test"
[nonrtric.git] / test / mrstub / basic_test.sh
1 #!/bin/bash
2
3 #  ============LICENSE_START===============================================
4 #  Copyright (C) 2020 Nordix Foundation. All rights reserved.
5 #  ========================================================================
6 #  Licensed under the Apache License, Version 2.0 (the "License");
7 #  you may not use this file except in compliance with the License.
8 #  You may obtain a copy of the License at
9 #
10 #       http://www.apache.org/licenses/LICENSE-2.0
11 #
12 #  Unless required by applicable law or agreed to in writing, software
13 #  distributed under the License is distributed on an "AS IS" BASIS,
14 #  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 #  See the License for the specific language governing permissions and
16 #  limitations under the License.
17 #  ============LICENSE_END=================================================
18 #
19
20 # Automated test script for mrstub container
21
22 # Run the build_and_start with the same arg as this script
23 if [ $# -ne 1 ]; then
24     echo "Usage: ./basic_test nonsecure|secure"
25     exit 1
26 fi
27 if [ "$1" != "nonsecure" ] && [ "$1" != "secure" ]; then
28     echo "Usage: ./basic_test nonsecure|secure"
29     exit 1
30 fi
31
32 if [ $1 == "nonsecure" ]; then
33     #Default http port for the simulator
34     PORT=3905
35     # Set http protocol
36     HTTPX="http"
37 else
38     #Default https port for the mr-stub
39     PORT=3906
40     # Set https protocol
41     HTTPX="https"
42 fi
43
44 # source function to do curl and check result
45 . ../common/do_curl_function.sh
46
47 echo "=== Stub hello world ==="
48 RESULT="OK"
49 do_curl GET / 200
50
51 echo "=== Stub reset ==="
52 RESULT="OK"
53 do_curl GET /reset 200
54
55 ## Test with json response
56
57 echo "=== Send a request ==="
58 RESULT="*"
59 #create payload
60 echo "{\"data\": \"data-value\"}" > .tmp.json
61
62 do_curl POST '/send-request?operation=PUT&url=/test' 200 .tmp.json
63 #Save id for later
64 CORRID=$body
65
66 echo "=== Fetch a response, shall be empty ==="
67 RESULT=""
68 do_curl GET '/receive-response?correlationid='$CORRID 204
69
70 echo "=== Fetch a request ==="
71 RESULT="json:[{\"apiVersion\":\"1.0\",\"operation\":\"PUT\",\"correlationId\":\""$CORRID"\",\"originatorId\": \"849e6c6b420\",\"payload\":{\"data\": \"data-value\"},\"requestId\":\"23343221\", \"target\":\"policy-agent\", \"timestamp\":\"????\", \"type\":\"request\",\"url\":\"/test\"}]"
72 do_curl GET '/events/A1-POLICY-AGENT-READ/users/policy-agent' 200
73
74 echo "=== Send a json response ==="
75 # Create minimal accepted response message
76 echo "[{\"correlationId\": \""$CORRID"\", \"message\": {\"test\":\"testresponse\"}, \"status\": \"200\"}]" > .tmp.json
77 RESULT="{}"
78 do_curl POST /events/A1-POLICY-AGENT-WRITE 200 .tmp.json
79
80 echo "=== Fetch a response ==="
81 RESULT="{\"test\": \"testresponse\"}200"
82 do_curl GET '/receive-response?correlationid='$CORRID 200
83
84 ### Test with plain text response
85
86 echo "=== Send a request ==="
87 RESULT="*"
88 do_curl POST '/send-request?operation=GET&url=/test2' 200
89 #Save id for later
90 CORRID=$body
91
92 echo "=== Fetch a response, shall be empty ==="
93 RESULT=""
94 do_curl GET '/receive-response?correlationid='$CORRID 204
95
96 echo "=== Fetch a request ==="
97 RESULT="json:[{\"apiVersion\":\"1.0\",\"operation\":\"GET\",\"correlationId\":\""$CORRID"\",\"originatorId\": \"849e6c6b420\",\"payload\":{},\"requestId\":\"23343221\", \"target\":\"policy-agent\", \"timestamp\":\"????\", \"type\":\"request\",\"url\":\"/test2\"}]"
98 do_curl GET '/events/A1-POLICY-AGENT-READ/users/policy-agent' 200
99
100 echo "=== Fetch a request, empty. Shall delay 10 seconds ==="
101 T1=$SECONDS
102 RESULT="json:[]"
103 do_curl GET '/events/A1-POLICY-AGENT-READ/users/policy-agent' 200
104 T2=$SECONDS
105 if [ $(($T2-$T1)) -lt 10 ] || [ $(($T2-$T1)) -gt 15 ]; then
106     echo "Delay to short or too long"$(($T2-$T1))". Should be default 10 sec"
107     exit 1
108 else
109     echo "  Delay ok:"$(($T2-$T1))
110 fi
111
112 echo "=== Fetch a request, empty. Shall delay 5 seconds ==="
113 T1=$SECONDS
114 RESULT="json:[]"
115 do_curl GET '/events/A1-POLICY-AGENT-READ/users/policy-agent?timeout=5000' 200
116 T2=$SECONDS
117 if [ $(($T2-$T1)) -lt 5 ] || [ $(($T2-$T1)) -gt 7 ]; then
118     echo "Delay too short or too long"$(($T2-$T1))". Should be 10 sec"
119     exit 1
120 else
121     echo "  Delay ok:"$(($T2-$T1))
122 fi
123
124 echo "=== Fetch a request with limit 25, shall be empty.  ==="
125 RESULT="json-array-size:0"
126 do_curl GET '/events/A1-POLICY-AGENT-READ/users/policy-agent?timeout=1000&limit=25' 200
127
128 echo "=== Send 5 request to test limit on MR GET==="
129 RESULT="*"
130 for i in {1..5}
131 do
132     do_curl POST '/send-request?operation=GET&url=/test2' 200
133 done
134
135 echo "=== Fetch a request with limit 3.  ==="
136 RESULT="json-array-size:3"
137 do_curl GET '/events/A1-POLICY-AGENT-READ/users/policy-agent?timeout=1000&limit=3' 200
138
139 echo "=== Fetch a request with limit 3, shall return 2.  ==="
140 RESULT="json-array-size:2"
141 do_curl GET '/events/A1-POLICY-AGENT-READ/users/policy-agent?timeout=1000&limit=3' 200
142
143 echo "=== Fetch a request with limit 3, shall return 0.  ==="
144 RESULT="json-array-size:0"
145 do_curl GET '/events/A1-POLICY-AGENT-READ/users/policy-agent?timeout=1000&limit=3' 200
146
147 echo "=== Send a json response ==="
148 # Create minimal accepted response message
149 echo "[{\"correlationId\": \""$CORRID"\", \"message\": \"test2-response\", \"status\": \"200\"}]" > .tmp.json
150 RESULT="{}"
151 do_curl POST /events/A1-POLICY-AGENT-WRITE 200 .tmp.json
152
153 echo "=== Fetch a response ==="
154 RESULT="test2-response200"
155 do_curl GET '/receive-response?correlationid='$CORRID 200
156
157 echo "********************"
158 echo "*** All tests ok ***"
159 echo "********************"