-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcurlCommandsPopulate..sh
More file actions
executable file
·80 lines (66 loc) · 3.21 KB
/
curlCommandsPopulate..sh
File metadata and controls
executable file
·80 lines (66 loc) · 3.21 KB
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
#!/bin/sh
# A shell script to invoke some sample curl commands on a Linux/Mac machine
# against a running container image of the app-specific Gilhari microservice
# gilhari_simple_example:1.0
#
# This scripts populates some data but does not delete them.
#
# The responses are recorded in a log file (curl.log).
#
# Note that these curl commands use a mapped port number of 80
# even though the port number exposed by the app-specific
# microservice may be different (e.g., 8081) inside the container shell.
# If you want to use these curl commands from inside the
# container shell on the host machine, you may have to use
# the exposed port number (e.g., 8081) instead.
# Check if a port is provided as an argument, if not, use default port 80
if [ -z "$1" ]; then
port=80
else
port=$1
fi
# Log file where output will be saved
log_file="curl.log"
# Start logging
echo "** BEGIN OUTPUT **" > "$log_file"
echo "" >> "$log_file"
# Log port information
echo "Using PORT number $port" >> "$log_file"
echo "" >> "$log_file"
echo "** Check the health of the Gilhari microservice" >> curl.log
curl -X GET "http://localhost:$port/gilhari/v1/health/check" >> curl.log
echo "" >> curl.log
echo "" >> curl.log
# ** Delete all Employee objects to start fresh
echo "** Delete all Employee objects to start fresh" >> "$log_file"
curl -X DELETE "http://localhost:$port/gilhari/v1/Employee" >> "$log_file"
echo "" >> "$log_file"
# ** Insert one Employee object
echo "** Insert one Employee object" >> "$log_file"
curl -X POST "http://localhost:$port/gilhari/v1/Employee" -H "Content-Type: application/json" -d '{"entity":{"id":39,"name":"John39","compensation":54039,"exempt":true,"DOB":381484800390}}' >> "$log_file"
echo "" >> "$log_file"
# ** Query all Employee objects
echo "** Query all Employee objects" >> "$log_file"
curl -X GET "http://localhost:$port/gilhari/v1/Employee" -H "Content-Type: application/json" >> "$log_file"
echo "" >> "$log_file"
# ** Insert multiple (two) Employee objects
echo "** Insert multiple (two) Employee objects" >> "$log_file"
curl -X POST "http://localhost:$port/gilhari/v1/Employee" -H "Content-Type: application/json" -d '{"entity":[{"id":40,"name":"Mike40","compensation":54040,"exempt":false,"DOB":381484800400}, {"id":41,"name":"Mary41","compensation":54041,"exempt":true,"DOB":381484800410}]}' >> "$log_file"
echo "" >> "$log_file"
# ** Query all Employee objects
echo "** Query all Employee objects" >> "$log_file"
curl -X GET "http://localhost:$port/gilhari/v1/Employee" -H "Content-Type: application/json" >> "$log_file"
echo "" >> "$log_file"
# ** Query non-exempted Employee objects
echo "** Query non-exempted Employee objects" >> "$log_file"
curl -X GET "http://localhost:$port/gilhari/v1/Employee?filter=exempt=0" -H "Content-Type: application/json" >> "$log_file"
echo "" >> "$log_file"
# ** Query the count of exempted Employee objects
echo "** Query the count of exempted Employee objects" >> "$log_file"
curl -X GET "http://localhost:$port/gilhari/v1/Employee/getAggregate?attribute=id&aggregateType=COUNT&filter=exempt=1" -H "Content-Type: application/json" >> "$log_file"
echo "" >> "$log_file"
# End logging
echo "** END OUTPUT **" >> "$log_file"
echo "" >> "$log_file"
# Display the log content
cat "$log_file"