2015-03-31 21:26:03 +00:00
|
|
|
from django.test import TestCase
|
|
|
|
from lifting.models import Exercise, Set
|
|
|
|
from lifting.importers import import_fitnotes_db
|
|
|
|
|
|
|
|
|
|
|
|
class TestFitnotesImport(TestCase):
|
|
|
|
# fitnotes.db has:
|
|
|
|
# April 1
|
|
|
|
# bench press 10 @ 45
|
|
|
|
# bench press 5 @ 95
|
|
|
|
# bench press 3 @ 135
|
|
|
|
# bench press 5 @ 155
|
|
|
|
# April 3
|
|
|
|
# squat 10 @ 45
|
|
|
|
# squat 5 @ 95
|
|
|
|
# squat 3 @ 135
|
|
|
|
# squat 2 @ 185
|
|
|
|
# squat 5 @ 225
|
|
|
|
|
2015-04-01 18:43:47 +00:00
|
|
|
def test_basic_import(self):
|
2015-04-01 21:19:28 +00:00
|
|
|
# ensure that the data comes in
|
2015-04-01 18:43:47 +00:00
|
|
|
import_fitnotes_db('lifting/testdata/example.fitnotes')
|
2015-03-31 21:26:03 +00:00
|
|
|
|
2015-04-01 18:43:47 +00:00
|
|
|
assert Exercise.objects.count() == 2
|
2015-04-01 21:19:28 +00:00
|
|
|
bp = Exercise.objects.get(names__contains=["flat barbell bench press"])
|
|
|
|
squat = Exercise.objects.get(names__contains=["barbell squat"])
|
|
|
|
assert Set.objects.count() == 9
|
2015-03-31 21:26:03 +00:00
|
|
|
|
2015-04-01 21:19:28 +00:00
|
|
|
def test_double_import(self):
|
|
|
|
# two identical dbs, should be idempotent
|
|
|
|
import_fitnotes_db('lifting/testdata/example.fitnotes')
|
|
|
|
import_fitnotes_db('lifting/testdata/example.fitnotes')
|
|
|
|
assert Exercise.objects.count() == 2
|
2015-04-01 18:43:47 +00:00
|
|
|
assert Set.objects.count() == 9
|
2015-04-01 21:31:25 +00:00
|
|
|
|
|
|
|
def test_bad_import(self):
|
|
|
|
# good db then bad db, should fail without screwing up existing data
|
|
|
|
import_fitnotes_db('lifting/testdata/example.fitnotes')
|
|
|
|
try:
|
|
|
|
# baddata.fitnotes has all exercise ids set to 9999
|
|
|
|
import_fitnotes_db('lifting/testdata/baddata.fitnotes')
|
|
|
|
except Exception:
|
|
|
|
pass
|
|
|
|
assert Exercise.objects.count() == 2
|
|
|
|
assert Set.objects.count() == 9
|