Add generation of API yaml file
[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, array
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 echo "=== Send a json response ==="
85 # Create minimal accepted response message, single message - no array
86 echo "{\"correlationId\": \""$CORRID"\", \"message\": {\"test\":\"testresponse2\"}, \"status\": \"200\"}" > .tmp.json
87 RESULT="{}"
88 do_curl POST /events/A1-POLICY-AGENT-WRITE 200 .tmp.json
89
90 echo "=== Fetch a response ==="
91 RESULT="{\"test\": \"testresponse2\"}200"
92 do_curl GET '/receive-response?correlationid='$CORRID 200
93
94 ### Test with plain text response
95
96 echo "=== Send a request ==="
97 RESULT="*"
98 do_curl POST '/send-request?operation=GET&url=/test2' 200
99 #Save id for later
100 CORRID=$body
101
102 echo "=== Fetch a response, shall be empty ==="
103 RESULT=""
104 do_curl GET '/receive-response?correlationid='$CORRID 204
105
106 echo "=== Fetch a request ==="
107 RESULT="json:[{\"apiVersion\":\"1.0\",\"operation\":\"GET\",\"correlationId\":\""$CORRID"\",\"originatorId\": \"849e6c6b420\",\"payload\":{},\"requestId\":\"23343221\", \"target\":\"policy-agent\", \"timestamp\":\"????\", \"type\":\"request\",\"url\":\"/test2\"}]"
108 do_curl GET '/events/A1-POLICY-AGENT-READ/users/policy-agent' 200
109
110 echo "=== Fetch a request, empty. Shall delay 10 seconds ==="
111 T1=$SECONDS
112 RESULT="json:[]"
113 do_curl GET '/events/A1-POLICY-AGENT-READ/users/policy-agent' 200
114 T2=$SECONDS
115 if [ $(($T2-$T1)) -lt 10 ] || [ $(($T2-$T1)) -gt 15 ]; then
116     echo "Delay to short or too long"$(($T2-$T1))". Should be default 10 sec"
117     exit 1
118 else
119     echo "  Delay ok:"$(($T2-$T1))
120 fi
121
122 echo "=== Fetch a request, empty. Shall delay 5 seconds ==="
123 T1=$SECONDS
124 RESULT="json:[]"
125 do_curl GET '/events/A1-POLICY-AGENT-READ/users/policy-agent?timeout=5000' 200
126 T2=$SECONDS
127 if [ $(($T2-$T1)) -lt 5 ] || [ $(($T2-$T1)) -gt 7 ]; then
128     echo "Delay too short or too long"$(($T2-$T1))". Should be 10 sec"
129     exit 1
130 else
131     echo "  Delay ok:"$(($T2-$T1))
132 fi
133
134 echo "=== Fetch a request with limit 25, shall be empty.  ==="
135 RESULT="json-array-size:0"
136 do_curl GET '/events/A1-POLICY-AGENT-READ/users/policy-agent?timeout=1000&limit=25' 200
137
138 echo "=== Send 5 request to test limit on MR GET==="
139 RESULT="*"
140 for i in {1..5}
141 do
142     do_curl POST '/send-request?operation=GET&url=/test2' 200
143 done
144
145 echo "=== Fetch a request with limit 3.  ==="
146 RESULT="json-array-size:3"
147 do_curl GET '/events/A1-POLICY-AGENT-READ/users/policy-agent?timeout=1000&limit=3' 200
148
149 echo "=== Fetch a request with limit 3, shall return 2.  ==="
150 RESULT="json-array-size:2"
151 do_curl GET '/events/A1-POLICY-AGENT-READ/users/policy-agent?timeout=1000&limit=3' 200
152
153 echo "=== Fetch a request with limit 3, shall return 0.  ==="
154 RESULT="json-array-size:0"
155 do_curl GET '/events/A1-POLICY-AGENT-READ/users/policy-agent?timeout=1000&limit=3' 200
156
157 echo "=== Send a json response ==="
158 # Create minimal accepted response message
159 echo "[{\"correlationId\": \""$CORRID"\", \"message\": \"test2-response\", \"status\": \"200\"}]" > .tmp.json
160 RESULT="{}"
161 do_curl POST /events/A1-POLICY-AGENT-WRITE 200 .tmp.json
162
163 echo "=== Fetch a response ==="
164 RESULT="test2-response200"
165 do_curl GET '/receive-response?correlationid='$CORRID 200
166
167 echo "********************"
168 echo "*** All tests ok ***"
169 echo "********************"