forked from bugzilla/bugzilla-schema
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpickle_schema.py
114 lines (107 loc) · 3.82 KB
/
pickle_schema.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
111
112
113
114
# Perforce Defect Tracking Integration Project
# <http://www.ravenbrook.com/project/p4dti/>
#
# PICKLE_SCHEMA.PY -- MAKE PICKLES OF BUGZILLA SCHEMAS
#
# Nick Barnes, Ravenbrook Limited, 2004-11-09
#
#
# 1. INTRODUCTION
#
# This module generates Python pickles of Bugzilla schemas, so that
# they can be included in generated schema documentation.
#
# The intended readership is project developers.
#
# This document is not confidential.
import MySQLdb
import cPickle
def fetchall(cursor):
rows = cursor.fetchall()
# for some reason, if no rows are returned sometimes one gets () here.
if len(rows) == 0:
rows = []
return rows
def select_rows(cursor, select):
rows = cursor.execute(select)
if cursor.description == None :
raise error, ("Trying to fetch rows from non-select '%s'"
% select)
values = fetchall(cursor)
if values == None :
raise error, ("Select '%s' returned unfetchable rows."
% select)
return values
def column_names(cursor):
keys = []
for i in range(len(cursor.description)):
keys.append(cursor.description[i][0])
return keys
def fetch_rows_as_list_of_dictionaries(cursor, select):
results = []
values = select_rows(cursor, select)
keys = column_names(cursor)
for value in values:
result={}
if len(keys) != len(value) :
raise error, ("Select '%s' returns %d keys but %d columns."
% (select, len(keys), len(value)))
for j in range(len(keys)):
result[keys[j]] = value[j]
results.append(result)
return results
def pickle_schema(schema_version, db_name):
db = MySQLdb.connect(db=db_name, user='bugs')
cursor = db.cursor()
tables = map(lambda x:x[0],select_rows(cursor, 'show tables'))
schema = {}
for table in tables:
columns = fetch_rows_as_list_of_dictionaries(cursor,
'describe %s' % table)
indexes = fetch_rows_as_list_of_dictionaries(cursor,
'show index from %s' % table)
schema[table] = (columns, indexes)
db.close()
f = open('pickles/%s' % schema_version, 'w')
cPickle.dump((schema_version, schema), f)
f.close()
# A. REFERENCES
#
#
# B. DOCUMENT HISTORY
#
# 2004-11-11 NB Created, partly from make_schema_doc.py.
#
#
# C. COPYRIGHT AND LICENSE
#
# This file is copyright (c) 2004 Perforce Software, Inc. All rights
# reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are
# met:
#
# 1. Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
#
# 2. Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in
# the documentation and/or other materials provided with the
# distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
# HOLDERS AND CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
# BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
# OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR
# TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
# USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
# DAMAGE.
#
#
# $Id$