mirror of
https://github.com/minio/minio.git
synced 2024-12-27 15:45:55 -05:00
5bd27346ac
Tests if imported service accounts have required access to buckets and objects. Signed-off-by: Shubhendu Ram Tripathi <shubhendu@minio.io> Co-authored-by: Harshavardhana <harsha@minio.io>
83 lines
2.3 KiB
Bash
Executable File
83 lines
2.3 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
if [ -n "$TEST_DEBUG" ]; then
|
|
set -x
|
|
fi
|
|
|
|
pkill minio
|
|
docker rm -f $(docker ps -aq)
|
|
rm -rf /tmp/openid{1..4}
|
|
|
|
export MC_HOST_myminio="http://minioadmin:minioadmin@localhost:22000"
|
|
# The service account used below is already present in iam configuration getting imported
|
|
export MC_HOST_myminio1="http://dillon-service-2:dillon-service-2@localhost:22000"
|
|
|
|
# Start MinIO instance
|
|
export CI=true
|
|
|
|
if [ ! -f ./mc ]; then
|
|
wget --quiet -O mc https://dl.minio.io/client/mc/release/linux-amd64/mc &&
|
|
chmod +x mc
|
|
fi
|
|
|
|
mc -v
|
|
|
|
# Start openid server
|
|
(
|
|
cd ./minio-iam-testing
|
|
make docker-images
|
|
make docker-run
|
|
cd -
|
|
)
|
|
|
|
(minio server --address :22000 --console-address :10000 http://localhost:22000/tmp/openid{1...4} 2>&1 >/tmp/server.log) &
|
|
./mc ready myminio
|
|
./mc mb myminio/test-bucket
|
|
./mc cp /etc/hosts myminio/test-bucket
|
|
|
|
./mc idp openid add myminio \
|
|
config_url="http://localhost:5556/dex/.well-known/openid-configuration" \
|
|
client_id="minio-client-app" \
|
|
client_secret="minio-client-app-secret" \
|
|
scopes="openid,groups,email,profile" \
|
|
redirect_uri="http://127.0.0.1:10000/oauth_callback" \
|
|
display_name="Login via dex1" \
|
|
role_policy="consoleAdmin"
|
|
|
|
./mc admin service restart myminio --json
|
|
./mc ready myminio
|
|
./mc admin cluster iam import myminio docs/distributed/samples/myminio-iam-info-openid.zip
|
|
|
|
# Verify if buckets / objects accessible using service account
|
|
echo "Verifying buckets and objects access for the imported service account"
|
|
|
|
./mc ls myminio1/ --json
|
|
BKT_COUNT=$(./mc ls myminio1/ --json | jq '.key' | wc -l)
|
|
if [ "${BKT_COUNT}" -ne 1 ]; then
|
|
echo "BUG: Expected no of bucket: 1, Found: ${BKT_COUNT}"
|
|
exit 1
|
|
fi
|
|
|
|
BKT_NAME=$(./mc ls myminio1/ --json | jq '.key' | sed 's/"//g' | sed 's\/\\g')
|
|
if [[ ${BKT_NAME} != "test-bucket" ]]; then
|
|
echo "BUG: Expected bucket: test-bucket, Found: ${BKT_NAME}"
|
|
exit 1
|
|
fi
|
|
|
|
./mc ls myminio1/test-bucket
|
|
OBJ_COUNT=$(./mc ls myminio1/test-bucket --json | jq '.key' | wc -l)
|
|
if [ "${OBJ_COUNT}" -ne 1 ]; then
|
|
echo "BUG: Expected no of objects: 1, Found: ${OBJ_COUNT}"
|
|
exit 1
|
|
fi
|
|
|
|
OBJ_NAME=$(./mc ls myminio1/test-bucket --json | jq '.key' | sed 's/"//g')
|
|
if [[ ${OBJ_NAME} != "hosts" ]]; then
|
|
echo "BUG: Expected object: hosts, Found: ${BKT_NAME}"
|
|
exit 1
|
|
fi
|
|
|
|
# Finally kill running processes
|
|
pkill minio
|
|
docker rm -f $(docker ps -aq)
|