add models, migrations and init_master_db command to webapp

This commit is contained in:
mdoglio 2013-03-11 16:49:10 +00:00
Родитель 6882628ba2
Коммит 60c5cc8cfc
8 изменённых файлов: 565 добавлений и 1 удалений

Просмотреть файл

@ -40,7 +40,7 @@ CREATE TABLE `bugscache` (
FULLTEXT KEY `idx_summary` (`summary`),
FULLTEXT KEY `idx_crash_signature` (`crash_signature`),
FULLTEXT KEY `idx_keywords` (`keywords`)
) ENGINE={engine} DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
/*!40101 SET character_set_client = @saved_cs_client */;
--

Просмотреть файл

@ -72,6 +72,7 @@ INSTALLED_APPS = [
'django.contrib.staticfiles',
'django.contrib.admin',
'treeherder.webapp',
'south',
]
# A sample logging configuration. The only tangible logging

Просмотреть файл

Просмотреть файл

Просмотреть файл

@ -0,0 +1,54 @@
import os
from optparse import make_option
from django.core.management.base import BaseCommand
from django.db import connection
from django.core.management import call_command
from django.utils.six.moves import input
class Command(BaseCommand):
help = "Init master database and call syncdb"
option_list = BaseCommand.option_list + (
make_option('--engine',
action='store',
dest='engine',
default='InnoDB',
help='Define the db engine to use.',
),
make_option('--template-path',
action='store',
dest='template_path',
default='treeherder/model/sql/template_schema/',
help='Directory containing the sql templates',
),
)
def handle(self, *args, **options):
confirm = input("""You have requested an init of the database.
This will IRREVERSIBLY DESTROY all data currently in the %r database,
and return each table to the state it was in after syncdb.
Are you sure you want to do this?
Type 'yes' to continue, or 'no' to cancel: """ % connection.settings_dict['NAME'])
if confirm == 'yes':
for sql_file in ('treeherder.sql.tmpl',
'treeherder_reference_1.sql.tmpl'):
sql = open(os.path.join(options['template_path'], sql_file)).read()
cursor = connection.cursor()
try:
rendered_sql = sql.format(engine=options['engine'])
cursor.execute(rendered_sql)
except Exception, e:
print "Error on sql execution:{0}".format(e)
finally:
cursor.close()
print "Sql files executed successfully."
#flush all the apps not under south
call_command("syncdb", interactive=False,)
#fake the first migration because manually generated
call_command("migrate", 'webapp','0001',fake=True)
#safely apply all the other migrations
call_command("migrate", 'webapp')

Просмотреть файл

@ -0,0 +1,352 @@
# -*- coding: utf-8 -*-
import datetime
from south.db import db
from south.v2 import SchemaMigration
from django.db import models
class Migration(SchemaMigration):
def forwards(self, orm):
# Adding model 'Product'
db.create_table(u'product', (
('id', self.gf('django.db.models.fields.IntegerField')(primary_key=True)),
('name', self.gf('django.db.models.fields.CharField')(max_length=50L)),
('description', self.gf('django.db.models.fields.TextField')()),
('active_status', self.gf('django.db.models.fields.CharField')(max_length=7L, blank=True)),
))
db.send_create_signal(u'webapp', ['Product'])
# Adding model 'BuildPlatform'
db.create_table(u'build_platform', (
('id', self.gf('django.db.models.fields.IntegerField')(primary_key=True)),
('os_name', self.gf('django.db.models.fields.CharField')(max_length=25L)),
('platform', self.gf('django.db.models.fields.CharField')(max_length=25L)),
('architecture', self.gf('django.db.models.fields.CharField')(max_length=25L, blank=True)),
('active_status', self.gf('django.db.models.fields.CharField')(max_length=7L, blank=True)),
))
db.send_create_signal(u'webapp', ['BuildPlatform'])
# Adding model 'Option'
db.create_table(u'option', (
('id', self.gf('django.db.models.fields.IntegerField')(primary_key=True)),
('name', self.gf('django.db.models.fields.CharField')(max_length=50L)),
('description', self.gf('django.db.models.fields.TextField')()),
('active_status', self.gf('django.db.models.fields.CharField')(max_length=7L, blank=True)),
))
db.send_create_signal(u'webapp', ['Option'])
# Adding model 'RepositoryGroup'
db.create_table(u'repository_group', (
('id', self.gf('django.db.models.fields.IntegerField')(primary_key=True)),
('name', self.gf('django.db.models.fields.CharField')(max_length=50L)),
('description', self.gf('django.db.models.fields.TextField')()),
('active_status', self.gf('django.db.models.fields.CharField')(max_length=7L, blank=True)),
))
db.send_create_signal(u'webapp', ['RepositoryGroup'])
# Adding model 'Repository'
db.create_table(u'repository', (
('id', self.gf('django.db.models.fields.IntegerField')(primary_key=True)),
('repository_group', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['webapp.RepositoryGroup'])),
('name', self.gf('django.db.models.fields.CharField')(max_length=50L)),
('type', self.gf('django.db.models.fields.CharField')(max_length=25L)),
('url', self.gf('django.db.models.fields.CharField')(max_length=255L)),
('branch', self.gf('django.db.models.fields.CharField')(max_length=50L, blank=True)),
('project_name', self.gf('django.db.models.fields.CharField')(max_length=25L, blank=True)),
('description', self.gf('django.db.models.fields.TextField')()),
('purpose', self.gf('django.db.models.fields.CharField')(max_length=50L)),
('active_status', self.gf('django.db.models.fields.CharField')(max_length=7L, blank=True)),
))
db.send_create_signal(u'webapp', ['Repository'])
# Adding model 'MachinePlatform'
db.create_table(u'machine_platform', (
('id', self.gf('django.db.models.fields.IntegerField')(primary_key=True)),
('os_name', self.gf('django.db.models.fields.CharField')(max_length=25L)),
('platform', self.gf('django.db.models.fields.CharField')(max_length=25L)),
('architecture', self.gf('django.db.models.fields.CharField')(max_length=25L, blank=True)),
('active_status', self.gf('django.db.models.fields.CharField')(max_length=7L, blank=True)),
))
db.send_create_signal(u'webapp', ['MachinePlatform'])
# Adding model 'Bugscache'
db.create_table(u'bugscache', (
('id', self.gf('django.db.models.fields.IntegerField')(primary_key=True)),
('status', self.gf('django.db.models.fields.CharField')(max_length=64L, blank=True)),
('resolution', self.gf('django.db.models.fields.CharField')(max_length=64L, blank=True)),
('summary', self.gf('django.db.models.fields.CharField')(max_length=255L)),
('crash_signature', self.gf('django.db.models.fields.TextField')(blank=True)),
('keywords', self.gf('django.db.models.fields.TextField')(blank=True)),
('os', self.gf('django.db.models.fields.CharField')(max_length=64L, blank=True)),
('modified', self.gf('django.db.models.fields.DateTimeField')(null=True, blank=True)),
))
db.send_create_signal(u'webapp', ['Bugscache'])
# Adding model 'Machine'
db.create_table(u'machine', (
('id', self.gf('django.db.models.fields.IntegerField')(primary_key=True)),
('name', self.gf('django.db.models.fields.CharField')(max_length=50L)),
('first_timestamp', self.gf('django.db.models.fields.IntegerField')()),
('last_timestamp', self.gf('django.db.models.fields.IntegerField')()),
('active_status', self.gf('django.db.models.fields.CharField')(max_length=7L, blank=True)),
))
db.send_create_signal(u'webapp', ['Machine'])
# Adding model 'MachineNote'
db.create_table(u'machine_note', (
('id', self.gf('django.db.models.fields.IntegerField')(primary_key=True)),
('machine', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['webapp.Machine'])),
('author', self.gf('django.db.models.fields.CharField')(max_length=50L)),
('machine_timestamp', self.gf('django.db.models.fields.IntegerField')()),
('active_status', self.gf('django.db.models.fields.CharField')(max_length=7L, blank=True)),
('note', self.gf('django.db.models.fields.TextField')(blank=True)),
))
db.send_create_signal(u'webapp', ['MachineNote'])
# Adding model 'Datasource'
db.create_table(u'datasource', (
('id', self.gf('django.db.models.fields.IntegerField')(primary_key=True)),
('project', self.gf('django.db.models.fields.CharField')(max_length=25L)),
('contenttype', self.gf('django.db.models.fields.CharField')(max_length=25L)),
('dataset', self.gf('django.db.models.fields.IntegerField')()),
('host', self.gf('django.db.models.fields.CharField')(max_length=128L)),
('read_only_host', self.gf('django.db.models.fields.CharField')(max_length=128L, blank=True)),
('name', self.gf('django.db.models.fields.CharField')(max_length=128L)),
('type', self.gf('django.db.models.fields.CharField')(max_length=25L)),
('oauth_consumer_key', self.gf('django.db.models.fields.CharField')(max_length=45L, blank=True)),
('oauth_consumer_secret', self.gf('django.db.models.fields.CharField')(max_length=45L, blank=True)),
('creation_date', self.gf('django.db.models.fields.DateTimeField')()),
('cron_batch', self.gf('django.db.models.fields.CharField')(max_length=45L, blank=True)),
))
db.send_create_signal(u'webapp', ['Datasource'])
# Adding model 'JobGroup'
db.create_table(u'job_group', (
('id', self.gf('django.db.models.fields.IntegerField')(primary_key=True)),
('symbol', self.gf('django.db.models.fields.CharField')(max_length=10L)),
('name', self.gf('django.db.models.fields.CharField')(max_length=50L)),
('description', self.gf('django.db.models.fields.TextField')()),
('active_status', self.gf('django.db.models.fields.CharField')(max_length=7L, blank=True)),
))
db.send_create_signal(u'webapp', ['JobGroup'])
# Adding model 'RepositoryVersion'
db.create_table(u'repository_version', (
('id', self.gf('django.db.models.fields.IntegerField')(primary_key=True)),
('repository', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['webapp.Repository'])),
('version', self.gf('django.db.models.fields.CharField')(max_length=50L)),
('timestamp', self.gf('django.db.models.fields.IntegerField')()),
('active_status', self.gf('django.db.models.fields.CharField')(max_length=7L, blank=True)),
))
db.send_create_signal(u'webapp', ['RepositoryVersion'])
# Adding model 'OptionCollection'
db.create_table(u'option_collection', (
('id', self.gf('django.db.models.fields.IntegerField')(primary_key=True)),
('option', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['webapp.Option'])),
))
db.send_create_signal(u'webapp', ['OptionCollection'])
# Adding model 'JobType'
db.create_table(u'job_type', (
('id', self.gf('django.db.models.fields.IntegerField')(primary_key=True)),
('job_group', self.gf('django.db.models.fields.related.ForeignKey')(to=orm['webapp.JobGroup'], null=True, blank=True)),
('symbol', self.gf('django.db.models.fields.CharField')(max_length=10L)),
('name', self.gf('django.db.models.fields.CharField')(max_length=50L)),
('description', self.gf('django.db.models.fields.TextField')()),
('active_status', self.gf('django.db.models.fields.CharField')(max_length=7L, blank=True)),
))
db.send_create_signal(u'webapp', ['JobType'])
# Adding model 'FailureClassification'
db.create_table(u'failure_classification', (
('id', self.gf('django.db.models.fields.IntegerField')(primary_key=True)),
('name', self.gf('django.db.models.fields.CharField')(max_length=50L)),
('description', self.gf('django.db.models.fields.TextField')()),
('active_status', self.gf('django.db.models.fields.CharField')(max_length=7L, blank=True)),
))
db.send_create_signal(u'webapp', ['FailureClassification'])
def backwards(self, orm):
# Deleting model 'Product'
db.delete_table(u'product')
# Deleting model 'BuildPlatform'
db.delete_table(u'build_platform')
# Deleting model 'Option'
db.delete_table(u'option')
# Deleting model 'RepositoryGroup'
db.delete_table(u'repository_group')
# Deleting model 'Repository'
db.delete_table(u'repository')
# Deleting model 'MachinePlatform'
db.delete_table(u'machine_platform')
# Deleting model 'Bugscache'
db.delete_table(u'bugscache')
# Deleting model 'Machine'
db.delete_table(u'machine')
# Deleting model 'MachineNote'
db.delete_table(u'machine_note')
# Deleting model 'Datasource'
db.delete_table(u'datasource')
# Deleting model 'JobGroup'
db.delete_table(u'job_group')
# Deleting model 'RepositoryVersion'
db.delete_table(u'repository_version')
# Deleting model 'OptionCollection'
db.delete_table(u'option_collection')
# Deleting model 'JobType'
db.delete_table(u'job_type')
# Deleting model 'FailureClassification'
db.delete_table(u'failure_classification')
models = {
u'webapp.bugscache': {
'Meta': {'object_name': 'Bugscache', 'db_table': "u'bugscache'"},
'crash_signature': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
'keywords': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
'modified': ('django.db.models.fields.DateTimeField', [], {'null': 'True', 'blank': 'True'}),
'os': ('django.db.models.fields.CharField', [], {'max_length': '64L', 'blank': 'True'}),
'resolution': ('django.db.models.fields.CharField', [], {'max_length': '64L', 'blank': 'True'}),
'status': ('django.db.models.fields.CharField', [], {'max_length': '64L', 'blank': 'True'}),
'summary': ('django.db.models.fields.CharField', [], {'max_length': '255L'})
},
u'webapp.buildplatform': {
'Meta': {'object_name': 'BuildPlatform', 'db_table': "u'build_platform'"},
'active_status': ('django.db.models.fields.CharField', [], {'max_length': '7L', 'blank': 'True'}),
'architecture': ('django.db.models.fields.CharField', [], {'max_length': '25L', 'blank': 'True'}),
'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
'os_name': ('django.db.models.fields.CharField', [], {'max_length': '25L'}),
'platform': ('django.db.models.fields.CharField', [], {'max_length': '25L'})
},
u'webapp.datasource': {
'Meta': {'object_name': 'Datasource', 'db_table': "u'datasource'"},
'contenttype': ('django.db.models.fields.CharField', [], {'max_length': '25L'}),
'creation_date': ('django.db.models.fields.DateTimeField', [], {}),
'cron_batch': ('django.db.models.fields.CharField', [], {'max_length': '45L', 'blank': 'True'}),
'dataset': ('django.db.models.fields.IntegerField', [], {}),
'host': ('django.db.models.fields.CharField', [], {'max_length': '128L'}),
'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
'name': ('django.db.models.fields.CharField', [], {'max_length': '128L'}),
'oauth_consumer_key': ('django.db.models.fields.CharField', [], {'max_length': '45L', 'blank': 'True'}),
'oauth_consumer_secret': ('django.db.models.fields.CharField', [], {'max_length': '45L', 'blank': 'True'}),
'project': ('django.db.models.fields.CharField', [], {'max_length': '25L'}),
'read_only_host': ('django.db.models.fields.CharField', [], {'max_length': '128L', 'blank': 'True'}),
'type': ('django.db.models.fields.CharField', [], {'max_length': '25L'})
},
u'webapp.failureclassification': {
'Meta': {'object_name': 'FailureClassification', 'db_table': "u'failure_classification'"},
'active_status': ('django.db.models.fields.CharField', [], {'max_length': '7L', 'blank': 'True'}),
'description': ('django.db.models.fields.TextField', [], {}),
'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
'name': ('django.db.models.fields.CharField', [], {'max_length': '50L'})
},
u'webapp.jobgroup': {
'Meta': {'object_name': 'JobGroup', 'db_table': "u'job_group'"},
'active_status': ('django.db.models.fields.CharField', [], {'max_length': '7L', 'blank': 'True'}),
'description': ('django.db.models.fields.TextField', [], {}),
'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
'name': ('django.db.models.fields.CharField', [], {'max_length': '50L'}),
'symbol': ('django.db.models.fields.CharField', [], {'max_length': '10L'})
},
u'webapp.jobtype': {
'Meta': {'object_name': 'JobType', 'db_table': "u'job_type'"},
'active_status': ('django.db.models.fields.CharField', [], {'max_length': '7L', 'blank': 'True'}),
'description': ('django.db.models.fields.TextField', [], {}),
'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
'job_group': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['webapp.JobGroup']", 'null': 'True', 'blank': 'True'}),
'name': ('django.db.models.fields.CharField', [], {'max_length': '50L'}),
'symbol': ('django.db.models.fields.CharField', [], {'max_length': '10L'})
},
u'webapp.machine': {
'Meta': {'object_name': 'Machine', 'db_table': "u'machine'"},
'active_status': ('django.db.models.fields.CharField', [], {'max_length': '7L', 'blank': 'True'}),
'first_timestamp': ('django.db.models.fields.IntegerField', [], {}),
'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
'last_timestamp': ('django.db.models.fields.IntegerField', [], {}),
'name': ('django.db.models.fields.CharField', [], {'max_length': '50L'})
},
u'webapp.machinenote': {
'Meta': {'object_name': 'MachineNote', 'db_table': "u'machine_note'"},
'active_status': ('django.db.models.fields.CharField', [], {'max_length': '7L', 'blank': 'True'}),
'author': ('django.db.models.fields.CharField', [], {'max_length': '50L'}),
'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
'machine': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['webapp.Machine']"}),
'machine_timestamp': ('django.db.models.fields.IntegerField', [], {}),
'note': ('django.db.models.fields.TextField', [], {'blank': 'True'})
},
u'webapp.machineplatform': {
'Meta': {'object_name': 'MachinePlatform', 'db_table': "u'machine_platform'"},
'active_status': ('django.db.models.fields.CharField', [], {'max_length': '7L', 'blank': 'True'}),
'architecture': ('django.db.models.fields.CharField', [], {'max_length': '25L', 'blank': 'True'}),
'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
'os_name': ('django.db.models.fields.CharField', [], {'max_length': '25L'}),
'platform': ('django.db.models.fields.CharField', [], {'max_length': '25L'})
},
u'webapp.option': {
'Meta': {'object_name': 'Option', 'db_table': "u'option'"},
'active_status': ('django.db.models.fields.CharField', [], {'max_length': '7L', 'blank': 'True'}),
'description': ('django.db.models.fields.TextField', [], {}),
'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
'name': ('django.db.models.fields.CharField', [], {'max_length': '50L'})
},
u'webapp.optioncollection': {
'Meta': {'object_name': 'OptionCollection', 'db_table': "u'option_collection'"},
'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
'option': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['webapp.Option']"})
},
u'webapp.product': {
'Meta': {'object_name': 'Product', 'db_table': "u'product'"},
'active_status': ('django.db.models.fields.CharField', [], {'max_length': '7L', 'blank': 'True'}),
'description': ('django.db.models.fields.TextField', [], {}),
'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
'name': ('django.db.models.fields.CharField', [], {'max_length': '50L'})
},
u'webapp.repository': {
'Meta': {'object_name': 'Repository', 'db_table': "u'repository'"},
'active_status': ('django.db.models.fields.CharField', [], {'max_length': '7L', 'blank': 'True'}),
'branch': ('django.db.models.fields.CharField', [], {'max_length': '50L', 'blank': 'True'}),
'description': ('django.db.models.fields.TextField', [], {}),
'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
'name': ('django.db.models.fields.CharField', [], {'max_length': '50L'}),
'project_name': ('django.db.models.fields.CharField', [], {'max_length': '25L', 'blank': 'True'}),
'purpose': ('django.db.models.fields.CharField', [], {'max_length': '50L'}),
'repository_group': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['webapp.RepositoryGroup']"}),
'type': ('django.db.models.fields.CharField', [], {'max_length': '25L'}),
'url': ('django.db.models.fields.CharField', [], {'max_length': '255L'})
},
u'webapp.repositorygroup': {
'Meta': {'object_name': 'RepositoryGroup', 'db_table': "u'repository_group'"},
'active_status': ('django.db.models.fields.CharField', [], {'max_length': '7L', 'blank': 'True'}),
'description': ('django.db.models.fields.TextField', [], {}),
'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
'name': ('django.db.models.fields.CharField', [], {'max_length': '50L'})
},
u'webapp.repositoryversion': {
'Meta': {'object_name': 'RepositoryVersion', 'db_table': "u'repository_version'"},
'active_status': ('django.db.models.fields.CharField', [], {'max_length': '7L', 'blank': 'True'}),
'id': ('django.db.models.fields.IntegerField', [], {'primary_key': 'True'}),
'repository': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['webapp.Repository']"}),
'timestamp': ('django.db.models.fields.IntegerField', [], {}),
'version': ('django.db.models.fields.CharField', [], {'max_length': '50L'})
}
}
complete_apps = ['webapp']

Просмотреть файл

Просмотреть файл

@ -0,0 +1,157 @@
# This is an auto-generated Django model module.
# You'll have to do the following manually to clean this up:
# * Rearrange models' order
# * Make sure each model has one field with primary_key=True
# Feel free to rename the models, but don't rename db_table values or field names.
#
# Also note: You'll have to insert the output of 'django-admin.py sqlcustom [appname]'
# into your database.
from __future__ import unicode_literals
from django.db import models
class Product(models.Model):
id = models.IntegerField(primary_key=True)
name = models.CharField(max_length=50L)
description = models.TextField()
active_status = models.CharField(max_length=7L, blank=True)
class Meta:
db_table = 'product'
class BuildPlatform(models.Model):
id = models.IntegerField(primary_key=True)
os_name = models.CharField(max_length=25L)
platform = models.CharField(max_length=25L)
architecture = models.CharField(max_length=25L, blank=True)
active_status = models.CharField(max_length=7L, blank=True)
class Meta:
db_table = 'build_platform'
class Option(models.Model):
id = models.IntegerField(primary_key=True)
name = models.CharField(max_length=50L)
description = models.TextField()
active_status = models.CharField(max_length=7L, blank=True)
class Meta:
db_table = 'option'
class RepositoryGroup(models.Model):
id = models.IntegerField(primary_key=True)
name = models.CharField(max_length=50L)
description = models.TextField()
active_status = models.CharField(max_length=7L, blank=True)
class Meta:
db_table = 'repository_group'
class Repository(models.Model):
id = models.IntegerField(primary_key=True)
repository_group = models.ForeignKey('RepositoryGroup')
name = models.CharField(max_length=50L)
type = models.CharField(max_length=25L)
url = models.CharField(max_length=255L)
branch = models.CharField(max_length=50L, blank=True)
project_name = models.CharField(max_length=25L, blank=True)
description = models.TextField()
purpose = models.CharField(max_length=50L)
active_status = models.CharField(max_length=7L, blank=True)
class Meta:
db_table = 'repository'
class MachinePlatform(models.Model):
id = models.IntegerField(primary_key=True)
os_name = models.CharField(max_length=25L)
platform = models.CharField(max_length=25L)
architecture = models.CharField(max_length=25L, blank=True)
active_status = models.CharField(max_length=7L, blank=True)
class Meta:
db_table = 'machine_platform'
class Bugscache(models.Model):
id = models.IntegerField(primary_key=True)
status = models.CharField(max_length=64L, blank=True)
resolution = models.CharField(max_length=64L, blank=True)
summary = models.CharField(max_length=255L)
crash_signature = models.TextField(blank=True)
keywords = models.TextField(blank=True)
os = models.CharField(max_length=64L, blank=True)
modified = models.DateTimeField(null=True, blank=True)
class Meta:
db_table = 'bugscache'
class Machine(models.Model):
id = models.IntegerField(primary_key=True)
name = models.CharField(max_length=50L)
first_timestamp = models.IntegerField()
last_timestamp = models.IntegerField()
active_status = models.CharField(max_length=7L, blank=True)
class Meta:
db_table = 'machine'
class MachineNote(models.Model):
id = models.IntegerField(primary_key=True)
machine = models.ForeignKey(Machine)
author = models.CharField(max_length=50L)
machine_timestamp = models.IntegerField()
active_status = models.CharField(max_length=7L, blank=True)
note = models.TextField(blank=True)
class Meta:
db_table = 'machine_note'
class Datasource(models.Model):
id = models.IntegerField(primary_key=True)
project = models.CharField(max_length=25L)
contenttype = models.CharField(max_length=25L)
dataset = models.IntegerField()
host = models.CharField(max_length=128L)
read_only_host = models.CharField(max_length=128L, blank=True)
name = models.CharField(max_length=128L)
type = models.CharField(max_length=25L)
oauth_consumer_key = models.CharField(max_length=45L, blank=True)
oauth_consumer_secret = models.CharField(max_length=45L, blank=True)
creation_date = models.DateTimeField()
cron_batch = models.CharField(max_length=45L, blank=True)
class Meta:
db_table = 'datasource'
class JobGroup(models.Model):
id = models.IntegerField(primary_key=True)
symbol = models.CharField(max_length=10L)
name = models.CharField(max_length=50L)
description = models.TextField()
active_status = models.CharField(max_length=7L, blank=True)
class Meta:
db_table = 'job_group'
class RepositoryVersion(models.Model):
id = models.IntegerField(primary_key=True)
repository = models.ForeignKey(Repository)
version = models.CharField(max_length=50L)
timestamp = models.IntegerField()
active_status = models.CharField(max_length=7L, blank=True)
class Meta:
db_table = 'repository_version'
class OptionCollection(models.Model):
id = models.IntegerField(primary_key=True)
option = models.ForeignKey(Option)
class Meta:
db_table = 'option_collection'
class JobType(models.Model):
id = models.IntegerField(primary_key=True)
job_group = models.ForeignKey(JobGroup, null=True, blank=True)
symbol = models.CharField(max_length=10L)
name = models.CharField(max_length=50L)
description = models.TextField()
active_status = models.CharField(max_length=7L, blank=True)
class Meta:
db_table = 'job_type'
class FailureClassification(models.Model):
id = models.IntegerField(primary_key=True)
name = models.CharField(max_length=50L)
description = models.TextField()
active_status = models.CharField(max_length=7L, blank=True)
class Meta:
db_table = 'failure_classification'