testutils.py, management/commands/testdata.py: oprava chyb v testutils.
V testdata se trida handle jmenuje jinak.
This commit is contained in:
parent
ee0fd9ac93
commit
2d93984872
2 changed files with 38 additions and 36 deletions
|
@ -17,7 +17,7 @@ User = django.contrib.auth.get_user_model()
|
||||||
class Command(BaseCommand):
|
class Command(BaseCommand):
|
||||||
help = "Clear database and load testing data."
|
help = "Clear database and load testing data."
|
||||||
|
|
||||||
def handle_noargs(self, **options):
|
def handle(self, *args, **options):
|
||||||
assert settings.DEBUG == True
|
assert settings.DEBUG == True
|
||||||
dbfile = settings.DATABASES['default']['NAME']
|
dbfile = settings.DATABASES['default']['NAME']
|
||||||
if os.path.exists(dbfile):
|
if os.path.exists(dbfile):
|
||||||
|
@ -26,8 +26,8 @@ class Command(BaseCommand):
|
||||||
call_command('migrate', noinput=True)
|
call_command('migrate', noinput=True)
|
||||||
self.stdout.write('Vytvarim uzivatele "admin" (heslo "admin") a pseudo-nahodna data ...')
|
self.stdout.write('Vytvarim uzivatele "admin" (heslo "admin") a pseudo-nahodna data ...')
|
||||||
create_test_data(size=8)
|
create_test_data(size=8)
|
||||||
self.stdout.write('Vytvoreno %d uzivatelu, %d skol, %d resitelu, %d rocniku, %d cisel,
|
self.stdout.write('Vytvoreno %d uzivatelu, %d skol, %d resitelu, %d rocniku, %d cisel,'
|
||||||
%d problemu, %d reseni.'.format(User.objects.count(), Skola.objects.count(),
|
' %d problemu, %d reseni.'.format(User.objects.count(), Skola.objects.count(),
|
||||||
Resitel.objects.count(), Rocnik.objects.count(), Cislo.objects.count(),
|
Resitel.objects.count(), Rocnik.objects.count(), Cislo.objects.count(),
|
||||||
Problem.objects.count(), Reseni.objects.count()))
|
Problem.objects.count(), Reseni.objects.count()))
|
||||||
|
|
||||||
|
|
|
@ -54,7 +54,7 @@ def create_test_data(size = 6, rnd = None):
|
||||||
#FIXME pridat kontaktni osobu alespon nekde
|
#FIXME pridat kontaktni osobu alespon nekde
|
||||||
skoly.append(zlinska = Skola.objects.create(mesto = 'Zlín', stat='CZ', psc='76001',
|
skoly.append(zlinska = Skola.objects.create(mesto = 'Zlín', stat='CZ', psc='76001',
|
||||||
ulice='náměstí T.G. Masaryka 2734-9', nazev='Gymnázium a Střední jazyková škola s právem SJZ',
|
ulice='náměstí T.G. Masaryka 2734-9', nazev='Gymnázium a Střední jazyková škola s právem SJZ',
|
||||||
kratky_nazev="GaSJŠspSJZ" je_zs=True, je_ss=True))
|
kratky_nazev="GaSJŠspSJZ", je_zs=True, je_ss=True))
|
||||||
|
|
||||||
# osoby
|
# osoby
|
||||||
jmena_m = ['Aleš', 'Tomáš', 'Martin', 'Jakub', 'Petr', 'Lukáš', 'Cyril', 'Pavel Karel']
|
jmena_m = ['Aleš', 'Tomáš', 'Martin', 'Jakub', 'Petr', 'Lukáš', 'Cyril', 'Pavel Karel']
|
||||||
|
@ -65,12 +65,12 @@ def create_test_data(size = 6, rnd = None):
|
||||||
'Suchá', 'Lovelace', 'Holcová', 'Rui']
|
'Suchá', 'Lovelace', 'Holcová', 'Rui']
|
||||||
prezdivka = ['Kaki', 'Hurdur', 'Maracuja', 'Bobbo', None, None, None, None, None, None, None,
|
prezdivka = ['Kaki', 'Hurdur', 'Maracuja', 'Bobbo', None, None, None, None, None, None, None,
|
||||||
'Riki', 'Sapa', None, '', '---', 'Koko']
|
'Riki', 'Sapa', None, '', '---', 'Koko']
|
||||||
name = [unidecode.unidecode(n) for n in jmena_m, jmena_f]
|
|
||||||
domain = ['example.com', 'dolujeme.eu', 'mff.cuni.cz', 'strcprstskrzkrk.cz', 'british.co.uk',
|
domain = ['example.com', 'dolujeme.eu', 'mff.cuni.cz', 'strcprstskrzkrk.cz', 'british.co.uk',
|
||||||
'splachni.to', 'haha.org' ]
|
'splachni.to', 'haha.org']
|
||||||
seznam_ulic = ['Krátká', 'Vlhká', 'Jungmanova', '17. listopadu', '4. října', 'Roztocká', 'Forstova',
|
seznam_ulic = ['Krátká', 'Vlhká', 'Jungmanova', '17. listopadu', '4. října', 'Roztocká',
|
||||||
'Generála Františka Janouška', 'Náměstí Války', 'Svratecké náměstí', 'Zelená lhota',
|
'Forstova', 'Generála Františka Janouška', 'Náměstí Války', 'Svratecké náměstí',
|
||||||
'Z Plynu', 'K Jezeru', 'U Kocourkova', 'Uštěpačná', 'Ostrorepská', 'Zubří']
|
'Zelená lhota', 'Z Plynu', 'K Jezeru', 'U Kocourkova', 'Uštěpačná', 'Ostrorepská',
|
||||||
|
'Zubří']
|
||||||
seznam_mest = ['Praha', 'Brno', 'Ostrava', 'Horní Jelení', 'Dolní Zábrdovice', 'Prdelkov',
|
seznam_mest = ['Praha', 'Brno', 'Ostrava', 'Horní Jelení', 'Dolní Zábrdovice', 'Prdelkov',
|
||||||
'Stará myslivna', 'Kocourkov', 'Šalingrad', 'Medvědí hora', 'Basilej',
|
'Stará myslivna', 'Kocourkov', 'Šalingrad', 'Medvědí hora', 'Basilej',
|
||||||
'Unterschiedlich', 'Old York', 'Lancastershire', 'Vóloďháza']
|
'Unterschiedlich', 'Old York', 'Lancastershire', 'Vóloďháza']
|
||||||
|
@ -81,7 +81,7 @@ def create_test_data(size = 6, rnd = None):
|
||||||
jmeno = rnd.choice([jmena_m, jmena_f][pohlavi])
|
jmeno = rnd.choice([jmena_m, jmena_f][pohlavi])
|
||||||
prijmeni = rnd.choice([prijmeni_m, prijmeni_f][pohlavi])
|
prijmeni = rnd.choice([prijmeni_m, prijmeni_f][pohlavi])
|
||||||
prezdivka = rnd.choice(prezdivka)
|
prezdivka = rnd.choice(prezdivka)
|
||||||
email = "@".join([rnd.choice(name), rnd.choice(domain)])
|
email = "@".join([unidecode.unidecode(jmeno), rnd.choice(domain)])
|
||||||
telefon = [rnd.choice([k for k in range(10)]) for i in range(10)]
|
telefon = [rnd.choice([k for k in range(10)]) for i in range(10)]
|
||||||
narozeni = datetime.date(rnd.randint(1980, 2020), rnd.randint(1, 12), rnd.randint(1, 28))
|
narozeni = datetime.date(rnd.randint(1980, 2020), rnd.randint(1, 12), rnd.randint(1, 28))
|
||||||
ulic = rnd.choice([seznam_ulic])
|
ulic = rnd.choice([seznam_ulic])
|
||||||
|
@ -93,7 +93,7 @@ def create_test_data(size = 6, rnd = None):
|
||||||
pohlavi_muz = pohlavi, email = email, telefon = telefon, datum_narozeni = narozeni,
|
pohlavi_muz = pohlavi, email = email, telefon = telefon, datum_narozeni = narozeni,
|
||||||
ulice = ulice, mesto = mesto, psc = psc,
|
ulice = ulice, mesto = mesto, psc = psc,
|
||||||
datum_registrace = datetime.date(rnd.randint(2019, 2029), rnd.randint(1, 12),
|
datum_registrace = datetime.date(rnd.randint(2019, 2029), rnd.randint(1, 12),
|
||||||
rnd.randint(1, 28)))
|
rnd.randint(1, 28))))
|
||||||
#TODO pridat foto male a velke. Jak?
|
#TODO pridat foto male a velke. Jak?
|
||||||
|
|
||||||
# resitele a organizatori
|
# resitele a organizatori
|
||||||
|
@ -102,9 +102,10 @@ def create_test_data(size = 6, rnd = None):
|
||||||
organizatori = []
|
organizatori = []
|
||||||
for os in osoby:
|
for os in osoby:
|
||||||
rand = rnd.randint(0, 8)
|
rand = rnd.randint(0, 8)
|
||||||
if not (rand % 8 = 0):
|
if not (rand % 8 == 0):
|
||||||
resitele.append(Resitel.objects.create(osoba = os, skola = rnd.choice([skoly]),
|
resitele.append(Resitel.objects.create(osoba = os, skola = rnd.choice([skoly]),
|
||||||
rok_maturity = rnd.randint(2019, 2029), zasilat = rnd.choice(Resitel.ZASILAT_CHOICES)))
|
rok_maturity = rnd.randint(2019, 2029),
|
||||||
|
zasilat = rnd.choice(Resitel.ZASILAT_CHOICES)))
|
||||||
else:
|
else:
|
||||||
pusobnost = rnd.randint(1, last_rocnik)
|
pusobnost = rnd.randint(1, last_rocnik)
|
||||||
od = 1993 + last_rocnik - pusobnost
|
od = 1993 + last_rocnik - pusobnost
|
||||||
|
@ -126,13 +127,14 @@ def create_test_data(size = 6, rnd = None):
|
||||||
for ci in range(1, cisel + 1):
|
for ci in range(1, cisel + 1):
|
||||||
if ci >= 3:
|
if ci >= 3:
|
||||||
vydano = datetime.date(r.prvni_rok, ci + 6, rnd.randint(1, 28))
|
vydano = datetime.date(r.prvni_rok, ci + 6, rnd.randint(1, 28))
|
||||||
deadline = datetime.date(r.prvni_rok, ci + 8, rnd.randint(1, 28)
|
deadline = datetime.date(r.prvni_rok, ci + 8, rnd.randint(1, 28))
|
||||||
else:
|
else:
|
||||||
vydano = datetime.date(r.druhy_rok, ci - 3, rnd.randint(1, 28)
|
vydano = datetime.date(r.druhy_rok, ci - 3, rnd.randint(1, 28))
|
||||||
# posledni 2 cisla v rocniku nemaji deadline
|
# posledni 2 cisla v rocniku nemaji deadline
|
||||||
if ci + 2 > cisel:
|
if (ci + 2 > cisel):
|
||||||
deadline = datetime.date(r.druhy_rok, ci - 1, rnd.randint(1, 28)
|
deadline = datetime.date(r.druhy_rok, ci - 1, rnd.randint(1, 28))
|
||||||
else: None
|
else:
|
||||||
|
deadline = None
|
||||||
cislo = Cislo.objects.create(rocnik = r, cislo = str(ci), datum_vydani=vydano,
|
cislo = Cislo.objects.create(rocnik = r, cislo = str(ci), datum_vydani=vydano,
|
||||||
datum_deadline=deadline, verejne_db=True)
|
datum_deadline=deadline, verejne_db=True)
|
||||||
slovnik_cisel[ci] = cislo
|
slovnik_cisel[ci] = cislo
|
||||||
|
@ -142,24 +144,24 @@ def create_test_data(size = 6, rnd = None):
|
||||||
# TODO: nagenerovat starsim rocnikum pohadku
|
# TODO: nagenerovat starsim rocnikum pohadku
|
||||||
|
|
||||||
# problemy resene v ci
|
# problemy resene v ci
|
||||||
seq='#ABCDEFGHIJKLMNOPQRSTUVWXYZ'
|
# seq='#ABCDEFGHIJKLMNOPQRSTUVWXYZ'
|
||||||
if ci >= 3:
|
# if ci >= 3:
|
||||||
for pi in range(1, ((size + 1) // 2) + 1):
|
# for pi in range(1, ((size + 1) // 2) + 1):
|
||||||
p = Problem.objects.create(autor = rnd.choice(orgs), cislo_zadani=cs[ci-2],
|
# p = Problem.objects.create(autor = rnd.choice(orgs), cislo_zadani=cs[ci-2],
|
||||||
cislo_reseni=cs[ci], opravovatel = rnd.choice(orgs), kod = str(pi),
|
# cislo_reseni=cs[ci], opravovatel = rnd.choice(orgs), kod = str(pi),
|
||||||
nazev = u'Dummy úloha %s-%s' % (seq[ci], seq[pi]),
|
# nazev = u'Dummy úloha %s-%s' % (seq[ci], seq[pi]),
|
||||||
stav = Problem.STAV_ZADANY, typ = Problem.TYP_ULOHA, body = rnd.randint(1, 5))
|
# stav = Problem.STAV_ZADANY, typ = Problem.TYP_ULOHA, body = rnd.randint(1, 5))
|
||||||
p.text_problemu = (u"<p>Text problému <strong>%s.%s %s</strong><em> [id %d]</em> za %d body.</p>" %
|
# p.text_problemu = (u"<p>Text problému <strong>%s.%s %s</strong><em> [id %d]</em> za %d body.</p>" %
|
||||||
(p.cislo_zadani.kod(), p.kod, p.nazev, p.id, p.body))
|
# (p.cislo_zadani.kod(), p.kod, p.nazev, p.id, p.body))
|
||||||
p.text_problemu_org = u"<p><strong>Neveřejný</strong> text problému.</p>"
|
# p.text_problemu_org = u"<p><strong>Neveřejný</strong> text problému.</p>"
|
||||||
p.save()
|
# p.save()
|
||||||
|
#
|
||||||
poc_reseni = rnd.randint(size // 2, size * 2)
|
# poc_reseni = rnd.randint(size // 2, size * 2)
|
||||||
res_sel = rnd.sample(resitele, min(poc_reseni, len(resitele) - 2))
|
# res_sel = rnd.sample(resitele, min(poc_reseni, len(resitele) - 2))
|
||||||
for resitel in res_sel:
|
# for resitel in res_sel:
|
||||||
res = Reseni.objects.create(problem = p, resitel = resitel,
|
# res = Reseni.objects.create(problem = p, resitel = resitel,
|
||||||
body = rnd.randint(0, p.body), cislo_body = cs[ci])
|
# body = rnd.randint(0, p.body), cislo_body = cs[ci])
|
||||||
|
#
|
||||||
# TODO: nahodne nagenerovat problemum reseni a prilohy reseni, hodnoceni
|
# TODO: nahodne nagenerovat problemum reseni a prilohy reseni, hodnoceni
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue