-
Notifications
You must be signed in to change notification settings - Fork 78
/
init_db.py
110 lines (85 loc) · 3.17 KB
/
init_db.py
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
# Copyright 2020 QuantStack
# Distributed under the terms of the Modified BSD License.
import random
import uuid
from quetz.config import Config
from quetz.database import get_session, init_db
from quetz.db_models import (
ApiKey,
Channel,
ChannelMember,
Identity,
Package,
PackageMember,
Profile,
User,
)
def init_test_db():
config = Config()
init_db(config.sqlalchemy_database_url)
db = get_session(config.sqlalchemy_database_url)
testUsers = []
try:
for index, username in enumerate(["alice", "bob", "carol", "dave"]):
user = User(id=uuid.uuid4().bytes, username=username)
identity = Identity(
provider="dummy",
identity_id=str(index),
username=username,
)
profile = Profile(name=username.capitalize(), avatar_url="/avatar.jpg")
user.identities.append(identity)
user.profile = profile
db.add(user)
testUsers.append(user)
for channel_index in range(30):
channel = Channel(
name=f"channel{channel_index}",
description=f"Description of channel{channel_index}",
private=False,
)
for package_index in range(random.randint(5, 100)):
package = Package(
name=f"package{package_index}",
description=f"Description of package{package_index}",
)
channel.packages.append(package)
test_user = testUsers[random.randint(0, len(testUsers) - 1)]
package_member = PackageMember(
package=package, channel=channel, user=test_user, role="owner"
)
db.add(package_member)
if channel_index == 0:
package = Package(name="xtensor", description="Description of xtensor")
channel.packages.append(package)
test_user = testUsers[random.randint(0, len(testUsers) - 1)]
package_member = PackageMember(
package=package, channel=channel, user=test_user, role="owner"
)
db.add(package_member)
# create API key
key = "E_KaBFstCKI9hTdPM7DQq56GglRHf2HW7tQtq6si370"
key_user = User(id=uuid.uuid4().bytes)
api_key = ApiKey(
key=key, description="test API key", user=key_user, owner=test_user
)
db.add(api_key)
key_package_member = PackageMember(
user=key_user,
channel_name=channel.name,
package_name=package.name,
role="maintainer",
)
db.add(key_package_member)
db.add(channel)
channel_member = ChannelMember(
channel=channel,
user=testUsers[random.randint(0, len(testUsers) - 1)],
role="owner",
)
db.add(channel_member)
db.commit()
finally:
db.close()
if __name__ == "__main__":
init_test_db()