Skip to content

Commit

Permalink
qa/workunits/mon/auth_key_rotation.sh: exercise pending key / rotation
Browse files Browse the repository at this point in the history
Signed-off-by: Sage Weil <[email protected]>
  • Loading branch information
liewegas authored and rzarzynski committed Sep 12, 2022
1 parent c3562e9 commit 39da18b
Show file tree
Hide file tree
Showing 2 changed files with 59 additions and 0 deletions.
1 change: 1 addition & 0 deletions qa/suites/rados/singleton/all/mon-auth-caps.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -17,3 +17,4 @@ tasks:
clients:
all:
- mon/auth_caps.sh
- mon/auth_key_rotation.sh
58 changes: 58 additions & 0 deletions qa/workunits/mon/auth_key_rotation.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,58 @@
#!/usr/bin/bash -ex

function expect_false()
{
set -x
if "$@"; then return 1; else return 0; fi
}


ceph auth export
ceph auth rm client.rot

ceph auth get-or-create client.rot mon 'allow rwx'
ceph auth export client.rot | grep key
ceph auth export client.rot | expect_false grep pending.key

ceph auth get-or-create-pending client.rot
ceph auth export client.rot | grep key
ceph auth export client.rot | grep pending.key

ceph auth clear-pending client.rot
ceph auth export client.rot | expect_false grep pending.key

ceph auth get-or-create-pending client.rot
ceph auth export client.rot | grep key
ceph auth export client.rot | grep pending.key
K=$(ceph auth export client.rot | grep 'key = ' | head -n 1 | awk '{print $3}')
PK=$(ceph auth export client.rot | grep pending.key | awk '{print $4}')
echo "K is $K"
echo "PK is $PK"
ceph -n client.rot --key $K -s

ceph auth commit-pending client.rot
ceph auth export client.rot | expect_false grep pending.key
ceph auth export client.rot | grep key | grep $PK

ceph auth get-or-create-pending client.rot
ceph auth export client.rot | grep key
ceph auth export client.rot | grep pending.key
K=$(ceph auth export client.rot | grep 'key = ' | head -n 1 | awk '{print $3}')
PK=$(ceph auth export client.rot | grep pending.key | awk '{print $4}')
echo "2, K is $K"
echo "2, PK is $PK"

ceph auth export client.rot

while ceph -n client.rot --key $K -s ; do
ceph auth export client.rot
ceph -n client.rot --key $PK -s
sleep 1
done

ceph auth export client.rot | expect_false grep pending.key
ceph auth export client.rot | grep key | grep $PK

ceph -n client.rot --key $PK -s

echo ok

0 comments on commit 39da18b

Please sign in to comment.