unit tests for notes
This commit is contained in:
parent
e63f2116cd
commit
ba42cedf1a
@ -647,8 +647,8 @@ class AnkiConnect:
|
|||||||
def addNote(self, note):
|
def addNote(self, note):
|
||||||
ankiNote = self.createNote(note)
|
ankiNote = self.createNote(note)
|
||||||
|
|
||||||
if note['audio'] is not None and len(note['audio']['fields']) > 0:
|
audio = note.get('audio')
|
||||||
audio = note['audio']
|
if audio is not None and len(audio['fields']) > 0:
|
||||||
data = download(audio['url'])
|
data = download(audio['url'])
|
||||||
if data is not None:
|
if data is not None:
|
||||||
if audio['skipHash'] is None:
|
if audio['skipHash'] is None:
|
||||||
@ -683,16 +683,16 @@ class AnkiConnect:
|
|||||||
|
|
||||||
|
|
||||||
@api()
|
@api()
|
||||||
def updateNoteFields(self, params):
|
def updateNoteFields(self, note):
|
||||||
note = self.collection().getNote(params['id'])
|
ankiNote = self.collection().getNote(note['id'])
|
||||||
if note is None:
|
if ankiNote is None:
|
||||||
raise Exception('note was not found: {}'.format(params['id']))
|
raise Exception('note was not found: {}'.format(note['id']))
|
||||||
|
|
||||||
for name, value in params['fields'].items():
|
for name, value in note['fields'].items():
|
||||||
if name in note:
|
if name in ankiNote:
|
||||||
note[name] = value
|
ankiNote[name] = value
|
||||||
|
|
||||||
note.flush()
|
ankiNote.flush()
|
||||||
|
|
||||||
|
|
||||||
@api()
|
@api()
|
||||||
|
105
tests/test_notes.py
Executable file
105
tests/test_notes.py
Executable file
@ -0,0 +1,105 @@
|
|||||||
|
#!/usr/bin/env python
|
||||||
|
|
||||||
|
import unittest
|
||||||
|
import util
|
||||||
|
|
||||||
|
|
||||||
|
class TestNotes(unittest.TestCase):
|
||||||
|
def setUp(self):
|
||||||
|
util.invoke('createDeck', deck='test')
|
||||||
|
|
||||||
|
|
||||||
|
def tearDown(self):
|
||||||
|
util.invoke('deleteDecks', decks=['test'], cardsToo=True)
|
||||||
|
|
||||||
|
|
||||||
|
def runTest(self):
|
||||||
|
note = {
|
||||||
|
'deckName': 'test',
|
||||||
|
'modelName': 'Basic',
|
||||||
|
'fields': {'Front': 'front1', 'Back': 'back1'},
|
||||||
|
'tags': ['tag1']
|
||||||
|
}
|
||||||
|
|
||||||
|
# addNote
|
||||||
|
noteId = util.invoke('addNote', note=note)
|
||||||
|
self.assertRaises(Exception, lambda: util.invoke('addNote', note=note))
|
||||||
|
|
||||||
|
# addTags
|
||||||
|
util.invoke('addTags', notes=[noteId], tags='tag2')
|
||||||
|
|
||||||
|
# notesInfo (part 1)
|
||||||
|
noteInfos = util.invoke('notesInfo', notes=[noteId])
|
||||||
|
self.assertEqual(len(noteInfos), 1)
|
||||||
|
noteInfo = noteInfos[0]
|
||||||
|
self.assertEqual(noteInfo['noteId'], noteId)
|
||||||
|
self.assertSetEqual(set(noteInfo['tags']), {'tag1', 'tag2'})
|
||||||
|
self.assertEqual(noteInfo['fields']['Front']['value'], 'front1')
|
||||||
|
self.assertEqual(noteInfo['fields']['Back']['value'], 'back1')
|
||||||
|
|
||||||
|
# getTags
|
||||||
|
allTags = util.invoke('getTags')
|
||||||
|
self.assertIn('tag1', allTags)
|
||||||
|
self.assertIn('tag2', allTags)
|
||||||
|
|
||||||
|
# removeTags
|
||||||
|
util.invoke('removeTags', notes=[noteId], tags='tag2')
|
||||||
|
|
||||||
|
# updateNoteFields
|
||||||
|
noteUpdate = {'id': noteId, 'fields': {'Front': 'front2', 'Back': 'back2'}}
|
||||||
|
util.invoke('updateNoteFields', note=noteUpdate)
|
||||||
|
|
||||||
|
# notesInfo (part 2)
|
||||||
|
noteInfos = util.invoke('notesInfo', notes=[noteId])
|
||||||
|
self.assertEqual(len(noteInfos), 1)
|
||||||
|
noteInfo = noteInfos[0]
|
||||||
|
self.assertSetEqual(set(noteInfo['tags']), {'tag1'})
|
||||||
|
self.assertIn('tag1', noteInfo['tags'])
|
||||||
|
self.assertNotIn('tag2', noteInfo['tags'])
|
||||||
|
self.assertEqual(noteInfo['fields']['Front']['value'], 'front2')
|
||||||
|
self.assertEqual(noteInfo['fields']['Back']['value'], 'back2')
|
||||||
|
|
||||||
|
notes = [
|
||||||
|
{
|
||||||
|
'deckName': 'test',
|
||||||
|
'modelName': 'Basic',
|
||||||
|
'fields': {'Front': 'front3', 'Back': 'back3'},
|
||||||
|
'tags': ['tag']
|
||||||
|
},
|
||||||
|
{
|
||||||
|
'deckName': 'test',
|
||||||
|
'modelName': 'Basic',
|
||||||
|
'fields': {'Front': 'front4', 'Back': 'back4'},
|
||||||
|
'tags': ['tag']
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
# canAddNotes (part 1)
|
||||||
|
noteStates = util.invoke('canAddNotes', notes=notes)
|
||||||
|
self.assertEqual(len(noteStates), len(notes))
|
||||||
|
self.assertNotIn(False, noteStates)
|
||||||
|
|
||||||
|
# addNotes (part 1)
|
||||||
|
noteIds = util.invoke('addNotes', notes=notes)
|
||||||
|
self.assertEqual(len(noteIds), len(notes))
|
||||||
|
for noteId in noteIds:
|
||||||
|
self.assertNotEqual(noteId, None)
|
||||||
|
|
||||||
|
# canAddNotes (part 2)
|
||||||
|
noteStates = util.invoke('canAddNotes', notes=notes)
|
||||||
|
self.assertNotIn(True, noteStates)
|
||||||
|
self.assertEqual(len(noteStates), len(notes))
|
||||||
|
|
||||||
|
# addNotes (part 2)
|
||||||
|
noteIds = util.invoke('addNotes', notes=notes)
|
||||||
|
self.assertEqual(len(noteIds), len(notes))
|
||||||
|
for noteId in noteIds:
|
||||||
|
self.assertEqual(noteId, None)
|
||||||
|
|
||||||
|
# findNotes
|
||||||
|
noteIds = util.invoke('findNotes', query='deck:test')
|
||||||
|
self.assertEqual(len(noteIds), len(notes) + 1)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
unittest.main()
|
Loading…
Reference in New Issue
Block a user