annotate PythonTrustStore-0.2.0/py_ts/testKMS.py @ 1:ff126718bdc5

Uploaded
author cathywise
date Wed, 11 Dec 2013 21:05:12 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
1 from py_ts import TrustStoreClient, ts_utils, parts
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
2 import argparse
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
3 import json
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
4 import sys
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
5 import psycopg2
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
6 import unittest
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
7
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
8 username = "foo4@test.com"
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
9 password = "password"
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
10 provider_file = "nectar.json"
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
11
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
12 class TestTruststoreAPI(unittest.TestCase):
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
13
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
14 def setUp(self):
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
15 self.ts = TrustStoreClient.TrustStoreClient(True, None, None)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
16 self.ts.authenticate(username=username, password=password)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
17
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
18 providers = None
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
19 with open(provider_file) as f:
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
20 providers = json.load(f)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
21 for provider in providers:
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
22 self.ts.addProvider(provider)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
23
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
24 keyFile = "truststore.pem"
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
25 keyFile = self.ts.getPrivateKey("truststore.pem")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
26 self.ts.keyFile = keyFile
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
27 if not keyFile:
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
28 print "No key file could be found! Check for errors above."
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
29 sys.exit(1)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
30
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
31 db = psycopg2.connect("dbname=kmscolab user=kmscolab password=kms1243")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
32 self.cur = db.cursor()
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
33
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
34
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
35 def test_empty_store(self):
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
36 """Testing an empty Store."""
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
37 blankStore = TrustStoreClient.Store()
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
38 blankStoreReturned = self.ts.createStore(store=blankStore)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
39 self.assertIsNone(blankStoreReturned)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
40
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
41 def test_no_owner_no_admin(self):
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
42 """Testing a store with no admin or owner."""
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
43 partialStore = TrustStoreClient.Store(friendly_name="test_no_owner_no_admin")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
44 partialStoreReturned = self.ts.createStore(store=partialStore)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
45 self.assertIsNone(partialStoreReturned)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
46
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
47 def test_no_admin(self):
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
48 """Testing a store with no admin."""
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
49 partialStore2 = TrustStoreClient.Store(owner=username, friendly_name="test_no_admin")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
50 partialStore2Returned = self.ts.createStore(store=partialStore2)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
51 self.assertIsNone(partialStore2Returned)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
52
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
53 def test_no_owner(self):
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
54 """Testing a store with no owner."""
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
55 partialStore3 = TrustStoreClient.Store(friendly_name="test_no_owner")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
56 partialStore3.administrators.append(username)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
57 partialStore3Returned = self.ts.createStore(store=partialStore3)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
58 self.assertIsNone(partialStore3Returned)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
59
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
60 def test_id_insert(self):
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
61 """Testing a store where we try and sneak in an ID"""
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
62 idStore = TrustStoreClient.Store(owner=username, friendly_name="test_id_insert")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
63 idStore.administrators.append(username)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
64 idStore.id = 10
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
65 idStoreReturned = self.ts.createStore(store=idStore)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
66 self.assertIsNotNone(idStoreReturned)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
67 self.assertNotEqual(idStore.id, idStoreReturned.id)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
68
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
69 print "Tests in database."
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
70 self.cur.execute("select friendly_name from stores where friendly_name ilike 'test\\_%';")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
71 self.assertEqual(len(self.cur.fetchall()), 1)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
72
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
73 self.ts.deleteStore(idStoreReturned)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
74
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
75 print "Tests in database (after deleting id test)."
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
76 self.cur.execute("select friendly_name from stores where friendly_name ilike 'test\\_%';")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
77 self.assertEqual(len(self.cur.fetchall()), 0)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
78
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
79 def test_bad_user(self):
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
80 """Test making a store where a user isn't valid."""
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
81 self.cur.execute("select count(*) from acl_entry;")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
82 aclCount = self.cur.fetchall()
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
83 badUserStore = TrustStoreClient.Store(owner=username, friendly_name="test_bad_user")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
84 badUserStore.administrators.append(username)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
85 badUserStore.readers.append("someone_not_real@gmail.com")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
86 badUserStoreReturned = self.ts.createStore(store=badUserStore)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
87 self.assertIsNone(badUserStoreReturned)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
88 self.cur.execute("select friendly_name from stores where friendly_name ilike 'test\\_%';")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
89 testStores = self.cur.fetchall()
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
90 self.assertEqual(len(testStores), 0)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
91 self.cur.execute("select count(*) from acl_entry;")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
92 self.assertEqual(self.cur.fetchall(), aclCount)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
93
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
94 def test_rights_savekey(self):
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
95 """Test if we can set a key we (probably) don't own."""
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
96 self.ts._setKeyForFragment("test-key", self.ts._generateKey(), 1)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
97 self.cur.execute("select codename, key, id from colabkeys where id = 1;")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
98 self.assertEqual(len(self.cur.fetchall()), 0)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
99
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
100 def test_nostore_savekey(self):
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
101 """Test if we can set a key for a deleted store."""
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
102 self.ts._setKeyForFragment("test-key-nostore", self.ts._generateKey(), 10)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
103 self.cur.execute("select codename, key, id from colabkeys where id = %s;", [10])
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
104 self.assertEqual(len(self.cur.fetchall()), 0)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
105
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
106 def test_rights_getkey(self):
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
107 """Test if we can get a key we don't own."""
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
108 key = self.ts._getKeyForFragment("d32fe69b-60c4-49c7-a160-44a5edaaf855", 49)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
109 self.assertIsNone(key)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
110
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
111 def test_good_savekey(self):
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
112 """Test if we can save & delete a key."""
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
113 storeid = self.ts.listStores()[0].id
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
114 frag = parts.Fragment()
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
115 frag.name = "test-key"
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
116 print "savekey"
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
117 self.ts._setKeyForFragment(frag.name, self.ts._generateKey(), storeid)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
118 self.ts._deleteKeysForFragments([frag], storeid)
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
119 print "deleted key"
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
120
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
121
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
122 if __name__ == '__main__':
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
123 # parser = argparse.ArgumentParser(description="TrustStore Command Line Client (pyts)")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
124 # parser.add_argument("user", help="TrustStore kms username")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
125 # parser.add_argument("password", help="TrustStore kms password")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
126 # parser.add_argument("provider", help="json file describing cloud service(s), including credentials")
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
127 # args = parser.parse_args()
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
128 # username = args.user
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
129 # password = args.password
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
130 # provider = args.provider
ff126718bdc5 Uploaded
cathywise
parents:
diff changeset
131 unittest.main()