2012-12-21 08:51:59 +01:00
|
|
|
# coding: utf-8
|
|
|
|
|
2014-06-03 10:38:47 +02:00
|
|
|
from tests.shared import getEmptyCol
|
2012-12-21 08:51:59 +01:00
|
|
|
|
2019-12-25 05:18:34 +01:00
|
|
|
|
2012-12-21 08:51:59 +01:00
|
|
|
def test_delete():
|
2014-06-03 10:38:47 +02:00
|
|
|
deck = getEmptyCol()
|
2012-12-21 08:51:59 +01:00
|
|
|
f = deck.newNote()
|
2019-12-25 05:18:34 +01:00
|
|
|
f["Front"] = "1"
|
|
|
|
f["Back"] = "2"
|
2012-12-21 08:51:59 +01:00
|
|
|
deck.addNote(f)
|
|
|
|
cid = f.cards()[0].id
|
|
|
|
deck.reset()
|
|
|
|
deck.sched.answerCard(deck.sched.getCard(), 2)
|
|
|
|
deck.remCards([cid])
|
|
|
|
assert deck.cardCount() == 0
|
|
|
|
assert deck.noteCount() == 0
|
|
|
|
assert deck.db.scalar("select count() from notes") == 0
|
|
|
|
assert deck.db.scalar("select count() from cards") == 0
|
|
|
|
assert deck.db.scalar("select count() from graves") == 2
|
|
|
|
|
2019-12-25 05:18:34 +01:00
|
|
|
|
2012-12-21 08:51:59 +01:00
|
|
|
def test_misc():
|
2014-06-03 10:38:47 +02:00
|
|
|
d = getEmptyCol()
|
2012-12-21 08:51:59 +01:00
|
|
|
f = d.newNote()
|
2019-12-25 05:18:34 +01:00
|
|
|
f["Front"] = "1"
|
|
|
|
f["Back"] = "2"
|
2012-12-21 08:51:59 +01:00
|
|
|
d.addNote(f)
|
|
|
|
c = f.cards()[0]
|
2019-12-25 05:18:34 +01:00
|
|
|
id = d.models.current()["id"]
|
|
|
|
assert c.template()["ord"] == 0
|
|
|
|
|
2012-12-21 08:51:59 +01:00
|
|
|
|
|
|
|
def test_genrem():
|
2014-06-03 10:38:47 +02:00
|
|
|
d = getEmptyCol()
|
2012-12-21 08:51:59 +01:00
|
|
|
f = d.newNote()
|
2019-12-25 05:18:34 +01:00
|
|
|
f["Front"] = "1"
|
|
|
|
f["Back"] = ""
|
2012-12-21 08:51:59 +01:00
|
|
|
d.addNote(f)
|
|
|
|
assert len(f.cards()) == 1
|
|
|
|
m = d.models.current()
|
|
|
|
mm = d.models
|
|
|
|
# adding a new template should automatically create cards
|
|
|
|
t = mm.newTemplate("rev")
|
2019-12-25 05:18:34 +01:00
|
|
|
t["qfmt"] = "{{Front}}"
|
|
|
|
t["afmt"] = ""
|
2012-12-21 08:51:59 +01:00
|
|
|
mm.addTemplate(m, t)
|
|
|
|
mm.save(m, templates=True)
|
|
|
|
assert len(f.cards()) == 2
|
|
|
|
# if the template is changed to remove cards, they'll be removed
|
2020-04-25 12:13:46 +02:00
|
|
|
t = m["tmpls"][1]
|
2019-12-25 05:18:34 +01:00
|
|
|
t["qfmt"] = "{{Back}}"
|
2012-12-21 08:51:59 +01:00
|
|
|
mm.save(m, templates=True)
|
2020-04-25 11:44:48 +02:00
|
|
|
rep = d.backend.empty_cards_report()
|
|
|
|
for note in rep.notes:
|
|
|
|
d.remCards(note.card_ids)
|
2012-12-21 08:51:59 +01:00
|
|
|
assert len(f.cards()) == 1
|
|
|
|
# if we add to the note, a card should be automatically generated
|
|
|
|
f.load()
|
2019-12-25 05:18:34 +01:00
|
|
|
f["Back"] = "1"
|
2012-12-21 08:51:59 +01:00
|
|
|
f.flush()
|
|
|
|
assert len(f.cards()) == 2
|
|
|
|
|
2019-12-25 05:18:34 +01:00
|
|
|
|
2012-12-21 08:51:59 +01:00
|
|
|
def test_gendeck():
|
2014-06-03 10:38:47 +02:00
|
|
|
d = getEmptyCol()
|
2012-12-21 08:51:59 +01:00
|
|
|
cloze = d.models.byName("Cloze")
|
|
|
|
d.models.setCurrent(cloze)
|
|
|
|
f = d.newNote()
|
2019-12-25 05:18:34 +01:00
|
|
|
f["Text"] = "{{c1::one}}"
|
2012-12-21 08:51:59 +01:00
|
|
|
d.addNote(f)
|
|
|
|
assert d.cardCount() == 1
|
|
|
|
assert f.cards()[0].did == 1
|
|
|
|
# set the model to a new default deck
|
|
|
|
newId = d.decks.id("new")
|
2019-12-25 05:18:34 +01:00
|
|
|
cloze["did"] = newId
|
2019-12-20 22:25:30 +01:00
|
|
|
d.models.save(cloze, updateReqs=False)
|
2012-12-21 08:51:59 +01:00
|
|
|
# a newly generated card should share the first card's deck
|
2019-12-25 05:18:34 +01:00
|
|
|
f["Text"] += "{{c2::two}}"
|
2012-12-21 08:51:59 +01:00
|
|
|
f.flush()
|
|
|
|
assert f.cards()[1].did == 1
|
|
|
|
# and same with multiple cards
|
2019-12-25 05:18:34 +01:00
|
|
|
f["Text"] += "{{c3::three}}"
|
2012-12-21 08:51:59 +01:00
|
|
|
f.flush()
|
|
|
|
assert f.cards()[2].did == 1
|
|
|
|
# if one of the cards is in a different deck, it should revert to the
|
|
|
|
# model default
|
|
|
|
c = f.cards()[1]
|
|
|
|
c.did = newId
|
|
|
|
c.flush()
|
2019-12-25 05:18:34 +01:00
|
|
|
f["Text"] += "{{c4::four}}"
|
2012-12-21 08:51:59 +01:00
|
|
|
f.flush()
|
|
|
|
assert f.cards()[3].did == newId
|