mirror of
https://github.com/iluvcapra/ptulsconv.git
synced 2026-01-01 17:30:47 +00:00
Updated unit tests
This commit is contained in:
@@ -1,6 +1,5 @@
|
||||
import unittest
|
||||
import ptulsconv
|
||||
#import pprint
|
||||
from ptulsconv.docparser import parse_document
|
||||
import os.path
|
||||
|
||||
|
||||
@@ -8,102 +7,77 @@ class TestRobinHood1(unittest.TestCase):
|
||||
path = os.path.dirname(__file__) + '/export_cases/Robin Hood Spotting.txt'
|
||||
|
||||
def test_header_export(self):
|
||||
with open(self.path, 'r') as f:
|
||||
visitor = ptulsconv.DictionaryParserVisitor()
|
||||
result = ptulsconv.protools_text_export_grammar.parse(f.read())
|
||||
parsed: dict = visitor.visit(result)
|
||||
|
||||
self.assertTrue('header' in parsed.keys())
|
||||
self.assertEqual(parsed['header']['session_name'], 'Robin Hood Spotting')
|
||||
self.assertEqual(parsed['header']['sample_rate'], 48000.0)
|
||||
self.assertEqual(parsed['header']['bit_depth'], 24)
|
||||
self.assertEqual(parsed['header']['timecode_format'], 29.97)
|
||||
self.assertEqual(parsed['header']['timecode_drop_frame'], False)
|
||||
session = parse_document(self.path)
|
||||
|
||||
self.assertIsNotNone(session.header)
|
||||
self.assertEqual(session.header.session_name, 'Robin Hood Spotting')
|
||||
self.assertEqual(session.header.sample_rate, 48000.0)
|
||||
self.assertEqual(session.header.bit_depth, 24)
|
||||
self.assertEqual(session.header.timecode_format, '29.97')
|
||||
self.assertEqual(session.header.timecode_drop_frame, False)
|
||||
|
||||
def test_all_sections(self):
|
||||
with open(self.path, 'r') as f:
|
||||
visitor = ptulsconv.DictionaryParserVisitor()
|
||||
result = ptulsconv.protools_text_export_grammar.parse(f.read())
|
||||
parsed: dict = visitor.visit(result)
|
||||
|
||||
self.assertIn('header', parsed.keys())
|
||||
self.assertIn('files', parsed.keys())
|
||||
self.assertIn('clips', parsed.keys())
|
||||
self.assertIn('plugins', parsed.keys())
|
||||
self.assertIn('tracks', parsed.keys())
|
||||
self.assertIn('markers', parsed.keys())
|
||||
session = parse_document(self.path)
|
||||
|
||||
self.assertIsNotNone(session.header)
|
||||
self.assertIsNotNone(session.files)
|
||||
self.assertIsNotNone(session.clips)
|
||||
self.assertIsNotNone(session.plugins)
|
||||
self.assertIsNotNone(session.tracks)
|
||||
self.assertIsNotNone(session.markers)
|
||||
|
||||
def test_tracks(self):
|
||||
with open(self.path, 'r') as f:
|
||||
visitor = ptulsconv.DictionaryParserVisitor()
|
||||
result = ptulsconv.protools_text_export_grammar.parse(f.read())
|
||||
parsed: dict = visitor.visit(result)
|
||||
self.assertEqual(len(parsed['tracks']), 14)
|
||||
self.assertListEqual(["Scenes", "Robin", "Will", "Marian", "John",
|
||||
"Guy", "Much", "Butcher", "Town Crier",
|
||||
"Soldier 1", "Soldier 2", "Soldier 3",
|
||||
"Priest", "Guest at Court"],
|
||||
list(map(lambda n: n['name'], parsed['tracks'])))
|
||||
self.assertListEqual(["", "[ADR] {Actor=Errol Flynn} $CN=1",
|
||||
"[ADR] {Actor=Patrick Knowles} $CN=2",
|
||||
"[ADR] {Actor=Olivia DeHavilland} $CN=3",
|
||||
"[ADR] {Actor=Claude Raines} $CN=4",
|
||||
"[ADR] {Actor=Basil Rathbone} $CN=5",
|
||||
"[ADR] {Actor=Herbert Mundin} $CN=6",
|
||||
"[ADR] {Actor=George Bunny} $CN=101",
|
||||
"[ADR] {Actor=Leonard Mundie} $CN=102",
|
||||
"[ADR] $CN=103",
|
||||
"[ADR] $CN=104",
|
||||
"[ADR] $CN=105",
|
||||
"[ADR] {Actor=Thomas R. Mills} $CN=106",
|
||||
"[ADR] $CN=107"],
|
||||
list(map(lambda n: n['comments'], parsed['tracks'])))
|
||||
|
||||
session = parse_document(self.path)
|
||||
|
||||
self.assertEqual(len(session.tracks), 14)
|
||||
self.assertListEqual(["Scenes", "Robin", "Will", "Marian", "John",
|
||||
"Guy", "Much", "Butcher", "Town Crier",
|
||||
"Soldier 1", "Soldier 2", "Soldier 3",
|
||||
"Priest", "Guest at Court"],
|
||||
list(map(lambda t: t.name, session.tracks)))
|
||||
self.assertListEqual(["", "[ADR] {Actor=Errol Flynn} $CN=1",
|
||||
"[ADR] {Actor=Patrick Knowles} $CN=2",
|
||||
"[ADR] {Actor=Olivia DeHavilland} $CN=3",
|
||||
"[ADR] {Actor=Claude Raines} $CN=4",
|
||||
"[ADR] {Actor=Basil Rathbone} $CN=5",
|
||||
"[ADR] {Actor=Herbert Mundin} $CN=6",
|
||||
"[ADR] {Actor=George Bunny} $CN=101",
|
||||
"[ADR] {Actor=Leonard Mundie} $CN=102",
|
||||
"[ADR] $CN=103",
|
||||
"[ADR] $CN=104",
|
||||
"[ADR] $CN=105",
|
||||
"[ADR] {Actor=Thomas R. Mills} $CN=106",
|
||||
"[ADR] $CN=107"],
|
||||
list(map(lambda t: t.comments, session.tracks)))
|
||||
|
||||
def test_a_track(self):
|
||||
with open(self.path, 'r') as f:
|
||||
visitor = ptulsconv.DictionaryParserVisitor()
|
||||
result = ptulsconv.protools_text_export_grammar.parse(f.read())
|
||||
parsed: dict = visitor.visit(result)
|
||||
guy_track = parsed['tracks'][5]
|
||||
self.assertEqual(guy_track['name'], 'Guy')
|
||||
self.assertEqual(guy_track['comments'], '[ADR] {Actor=Basil Rathbone} $CN=5')
|
||||
self.assertEqual(guy_track['user_delay_samples'], 0)
|
||||
self.assertListEqual(guy_track['state'], [])
|
||||
self.assertEqual(len(guy_track['clips']), 16)
|
||||
self.assertEqual(guy_track['clips'][5]['channel'], 1)
|
||||
self.assertEqual(guy_track['clips'][5]['event'], 6)
|
||||
self.assertEqual(guy_track['clips'][5]['clip_name'], "\"What's your name? You Saxon dog!\" $QN=GY106")
|
||||
self.assertEqual(guy_track['clips'][5]['start_time'], "01:04:19:15")
|
||||
self.assertEqual(guy_track['clips'][5]['end_time'], "01:04:21:28")
|
||||
self.assertEqual(guy_track['clips'][5]['duration'], "00:00:02:13")
|
||||
self.assertEqual(guy_track['clips'][5]['timestamp'], None)
|
||||
self.assertEqual(guy_track['clips'][5]['state'], 'Unmuted')
|
||||
session = parse_document(self.path)
|
||||
guy_track = session.tracks[5]
|
||||
self.assertEqual(guy_track.name, 'Guy')
|
||||
self.assertEqual(guy_track.comments, '[ADR] {Actor=Basil Rathbone} $CN=5')
|
||||
self.assertEqual(guy_track.user_delay_samples, 0)
|
||||
self.assertListEqual(guy_track.state, [])
|
||||
self.assertEqual(len(guy_track.clips), 16)
|
||||
self.assertEqual(guy_track.clips[5].channel, 1)
|
||||
self.assertEqual(guy_track.clips[5].event, 6)
|
||||
self.assertEqual(guy_track.clips[5].clip_name, "\"What's your name? You Saxon dog!\" $QN=GY106")
|
||||
self.assertEqual(guy_track.clips[5].start_timecode, "01:04:19:15")
|
||||
self.assertEqual(guy_track.clips[5].finish_timecode, "01:04:21:28")
|
||||
self.assertEqual(guy_track.clips[5].duration, "00:00:02:13")
|
||||
self.assertEqual(guy_track.clips[5].timestamp, None)
|
||||
self.assertEqual(guy_track.clips[5].state, 'Unmuted')
|
||||
|
||||
def test_memory_locations(self):
|
||||
with open(self.path, 'r') as f:
|
||||
visitor = ptulsconv.DictionaryParserVisitor()
|
||||
result = ptulsconv.protools_text_export_grammar.parse(f.read())
|
||||
parsed: dict = visitor.visit(result)
|
||||
|
||||
self.assertEqual(len(parsed['markers']),1)
|
||||
self.assertEqual(parsed['markers'][0]['number'], 1)
|
||||
self.assertEqual(parsed['markers'][0]['location'], "01:00:00:00")
|
||||
self.assertEqual(parsed['markers'][0]['time_reference'], 0)
|
||||
self.assertEqual(parsed['markers'][0]['units'], "Samples")
|
||||
|
||||
def test_transform_timecode(self):
|
||||
parsed = dict()
|
||||
with open(self.path, 'r') as f:
|
||||
visitor = ptulsconv.DictionaryParserVisitor()
|
||||
result = ptulsconv.protools_text_export_grammar.parse(f.read())
|
||||
parsed = visitor.visit(result)
|
||||
|
||||
xformer = ptulsconv.TimecodeInterpreter()
|
||||
xformer.apply_session_start = True
|
||||
|
||||
xformed = xformer.transform(parsed)
|
||||
|
||||
session = parse_document(self.path)
|
||||
|
||||
self.assertEqual(len(session.markers), 1)
|
||||
self.assertEqual(session.markers[0].number, 1)
|
||||
self.assertEqual(session.markers[0].location, "01:00:00:00")
|
||||
self.assertEqual(session.markers[0].time_reference, 0)
|
||||
self.assertEqual(session.markers[0].units, "Samples")
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
|
||||
Reference in New Issue
Block a user