2017-04-12 17:38:24 +08:00
|
|
|
#!/usr/bin/python
|
|
|
|
|
|
|
|
import unittest
|
|
|
|
import sgprops
|
|
|
|
import os
|
|
|
|
import catalog
|
|
|
|
import lxml.etree as ET
|
|
|
|
|
2018-03-10 21:10:20 +08:00
|
|
|
catalog.quiet = True
|
|
|
|
|
2017-04-12 17:38:24 +08:00
|
|
|
class UpdateCatalogTests(unittest.TestCase):
|
|
|
|
def test_scan_set(self):
|
|
|
|
info = catalog.scan_set_file("testData/Aircraft/f16", "f16a-set.xml", ["testData/OtherDir"])
|
|
|
|
self.assertEqual(info['id'], 'f16a')
|
|
|
|
self.assertEqual(info['name'], 'F16-A')
|
|
|
|
self.assertEqual(info['primary-set'], True)
|
|
|
|
self.assertEqual(info['variant-of'], None)
|
|
|
|
self.assertEqual(info['rating_FDM'], 3)
|
|
|
|
self.assertEqual(info['rating_model'], 5)
|
|
|
|
self.assertEqual(len(info['tags']), 3)
|
2017-07-31 01:38:04 +08:00
|
|
|
self.assertEqual(info['minimum-fg-version'], '2017.4')
|
2017-04-12 17:38:24 +08:00
|
|
|
|
2018-03-10 21:10:20 +08:00
|
|
|
authorsArray = info['authors']
|
|
|
|
self.assertNotIn('author', info)
|
|
|
|
self.assertEqual(len(authorsArray), 2)
|
|
|
|
|
|
|
|
author0 = authorsArray[0]
|
|
|
|
self.assertEqual(author0['name'], 'Wilbur Wright')
|
|
|
|
self.assertEqual(author0['nick'], 'wilburw')
|
|
|
|
self.assertEqual(author0['email'], 'ww@wright.com')
|
|
|
|
|
|
|
|
author1 = authorsArray[1]
|
|
|
|
self.assertEqual(author1['name'], 'Orville Wright')
|
|
|
|
# self.assertNotIn('nick', author1)
|
|
|
|
# self.assertNotIn('email', author1)
|
|
|
|
|
2017-04-12 17:38:24 +08:00
|
|
|
def test_scan_dir(self):
|
|
|
|
(pkg, variants) = catalog.scan_aircraft_dir("testData/Aircraft/f16", ["testData/OtherDir"])
|
|
|
|
|
|
|
|
self.assertEqual(pkg['id'], 'f16a')
|
|
|
|
f16trainer = next(v for v in variants if v['id'] == 'f16-trainer')
|
|
|
|
self.assertEqual(len(variants), 3)
|
2017-07-31 01:38:04 +08:00
|
|
|
self.assertEqual(pkg['minimum-fg-version'], '2017.4')
|
2017-04-12 17:38:24 +08:00
|
|
|
|
|
|
|
# test variant relatonship between
|
|
|
|
self.assertEqual(pkg['variant-of'], None)
|
|
|
|
self.assertEqual(pkg['primary-set'], True)
|
|
|
|
|
|
|
|
self.assertEqual(f16trainer['variant-of'], None)
|
|
|
|
self.assertEqual(f16trainer['primary-set'], False)
|
|
|
|
|
|
|
|
f16b = next(v for v in variants if v['id'] == 'f16b')
|
|
|
|
self.assertEqual(f16b['variant-of'], 'f16a')
|
|
|
|
self.assertEqual(f16b['primary-set'], False)
|
2018-03-10 21:10:20 +08:00
|
|
|
|
|
|
|
authorsArray = f16b['authors']
|
|
|
|
self.assertNotIn('author', f16b)
|
|
|
|
self.assertEqual(len(authorsArray), 2)
|
|
|
|
|
|
|
|
author0 = authorsArray[0]
|
|
|
|
self.assertEqual(author0['name'], 'James T Kirk')
|
|
|
|
self.assertEqual(author0['nick'], 'starlover')
|
2017-04-12 17:38:24 +08:00
|
|
|
|
|
|
|
f16c = next(v for v in variants if v['id'] == 'f16c')
|
|
|
|
self.assertEqual(f16c['variant-of'], 'f16a')
|
|
|
|
self.assertEqual(f16c['primary-set'], False)
|
|
|
|
|
2018-03-10 21:10:20 +08:00
|
|
|
authorsArray = f16c['authors']
|
|
|
|
self.assertNotIn('author', f16c)
|
|
|
|
self.assertEqual(len(authorsArray), 2)
|
2017-04-12 17:38:24 +08:00
|
|
|
|
2018-03-10 21:10:20 +08:00
|
|
|
# test some older constructs for compat
|
|
|
|
def test_scan_dir_legacy(self):
|
|
|
|
(pkg, variants) = catalog.scan_aircraft_dir("testData/Aircraft/c172", [])
|
|
|
|
|
|
|
|
self.assertEqual(pkg['id'], 'c172')
|
|
|
|
self.assertEqual(pkg['author'], 'Wilbur Wright')
|
2017-04-12 17:38:24 +08:00
|
|
|
|
|
|
|
def test_extract_previews(self):
|
|
|
|
info = catalog.scan_set_file("testData/Aircraft/f16", "f16a-set.xml", ["testData/OtherDir"])
|
|
|
|
previews = info['previews']
|
|
|
|
self.assertEqual(len(previews), 3)
|
|
|
|
self.assertEqual(2, len([p for p in previews if p['type'] == 'exterior']))
|
|
|
|
self.assertEqual(1, len([p for p in previews if p['type'] == 'panel']))
|
|
|
|
self.assertEqual(1, len([p for p in previews if p['path'] == 'Previews/exterior-1.png']))
|
|
|
|
|
|
|
|
def test_extract_tags(self):
|
|
|
|
info = catalog.scan_set_file("testData/Aircraft/f16", "f16a-set.xml", ["testData/OtherDir"])
|
|
|
|
tags = info['tags']
|
|
|
|
|
|
|
|
def test_node_creation(self):
|
|
|
|
(pkg, variants) = catalog.scan_aircraft_dir("testData/Aircraft/f16", ["testData/OtherDir"])
|
|
|
|
|
|
|
|
catalog_node = ET.Element('PropertyList')
|
|
|
|
catalog_root = ET.ElementTree(catalog_node)
|
|
|
|
|
|
|
|
pkgNode = catalog.make_aircraft_node('f16', pkg, variants, "http://foo.com/testOutput/")
|
|
|
|
catalog_node.append(pkgNode)
|
|
|
|
|
|
|
|
# write out so we can parse using sgprops
|
|
|
|
# yes we are round-tripping via the disk, if you can improve
|
|
|
|
# then feel free..
|
|
|
|
if not os.path.isdir("testOutput"):
|
|
|
|
os.mkdir("testOutput")
|
|
|
|
|
|
|
|
cat_file = os.path.join("testOutput", 'catalog_fragment.xml')
|
|
|
|
catalog_root.write(cat_file, encoding='utf-8', xml_declaration=True, pretty_print=True)
|
|
|
|
|
|
|
|
parsed = sgprops.readProps(cat_file)
|
|
|
|
parsedPkgNode = parsed.getChild("package")
|
|
|
|
|
|
|
|
self.assertEqual(parsedPkgNode.name, "package");
|
|
|
|
|
|
|
|
self.assertEqual(parsedPkgNode.getValue('id'), pkg['id']);
|
|
|
|
self.assertEqual(parsedPkgNode.getValue('dir'), 'f16');
|
|
|
|
self.assertEqual(parsedPkgNode.getValue('url'), 'http://foo.com/testOutput/f16.zip');
|
|
|
|
self.assertEqual(parsedPkgNode.getValue('thumbnail'), 'http://foo.com/testOutput/thumbnails/f16_thumbnail.jpg');
|
|
|
|
self.assertEqual(parsedPkgNode.getValue('thumbnail-path'), 'thumbnail.jpg');
|
|
|
|
|
|
|
|
self.assertEqual(parsedPkgNode.getValue('name'), pkg['name']);
|
|
|
|
self.assertEqual(parsedPkgNode.getValue('description'), pkg['description']);
|
|
|
|
|
2017-07-31 01:38:04 +08:00
|
|
|
self.assertEqual(parsedPkgNode.getValue('minimum-fg-version'), "2017.4");
|
|
|
|
|
2017-04-12 17:38:24 +08:00
|
|
|
parsedVariants = parsedPkgNode.getChildren("variant")
|
|
|
|
self.assertEqual(len(parsedVariants), 3)
|
|
|
|
|
2018-03-10 21:10:20 +08:00
|
|
|
# author data verification
|
|
|
|
self.assertFalse(parsedPkgNode.hasChild('author'));
|
|
|
|
parsedAuthors = parsedPkgNode.getChild("authors").getChildren('author')
|
|
|
|
|
|
|
|
self.assertEqual(len(parsedAuthors), 2)
|
|
|
|
author1 = parsedAuthors[0]
|
|
|
|
self.assertEqual(author1.getValue("name"), "Wilbur Wright")
|
|
|
|
self.assertEqual(author1.getValue("nick"), "wilburw")
|
|
|
|
self.assertEqual(author1.getValue("email"), "ww@wright.com")
|
|
|
|
|
|
|
|
author2 = parsedAuthors[1]
|
|
|
|
self.assertEqual(author2.getValue("name"), "Orville Wright")
|
|
|
|
|
2017-04-12 17:38:24 +08:00
|
|
|
f16ANode = parsedPkgNode
|
|
|
|
self.assertEqual(f16ANode.getValue('name'), 'F16-A');
|
|
|
|
|
|
|
|
for index, pv in enumerate(parsedVariants):
|
|
|
|
var = variants[index]
|
|
|
|
self.assertEqual(pv.getValue('name'), var['name']);
|
|
|
|
self.assertEqual(pv.getValue('description'), var['description']);
|
|
|
|
|
|
|
|
if (var['id'] == 'f16-trainer'):
|
|
|
|
self.assertEqual(pv.getValue('variant-of'), '_primary_')
|
2018-03-10 21:10:20 +08:00
|
|
|
# self.assertEqual(pv.getValue('author'), "Wilbur Wright");
|
2017-04-12 17:38:24 +08:00
|
|
|
elif (var['id'] == 'f16b'):
|
|
|
|
self.assertEqual(pv.getValue('variant-of'), 'f16a')
|
|
|
|
self.assertEqual(pv.getValue('description'), 'The F16-B is an upgraded version of the F16A.')
|
2018-03-10 21:10:20 +08:00
|
|
|
|
|
|
|
# variant author verification
|
|
|
|
parsedAuthors = pv.getChild("authors").getChildren('author')
|
|
|
|
author1 = parsedAuthors[0]
|
|
|
|
self.assertEqual(author1.getValue("name"), "James T Kirk")
|
|
|
|
self.assertEqual(author1.getValue("nick"), "starlover")
|
|
|
|
self.assertEqual(author1.getValue("email"), "shatner@enterprise.com")
|
|
|
|
self.assertEqual(author1.getValue("description"), "Everything")
|
2017-04-12 17:38:24 +08:00
|
|
|
|
2017-07-31 01:38:04 +08:00
|
|
|
def test_minimalAircraft(self):
|
|
|
|
# test an aircraft with a deliberately spartan -set.xml file with
|
|
|
|
# most interesting data missing
|
|
|
|
(pkg, variants) = catalog.scan_aircraft_dir("testData/Aircraft/c150", ["testData/OtherDir"])
|
2017-04-12 17:38:24 +08:00
|
|
|
|
2017-07-31 01:38:04 +08:00
|
|
|
catalog_node = ET.Element('PropertyList')
|
|
|
|
catalog_root = ET.ElementTree(catalog_node)
|
2017-04-12 17:38:24 +08:00
|
|
|
|
2017-07-31 01:38:04 +08:00
|
|
|
pkgNode = catalog.make_aircraft_node('c150', pkg, variants, "http://foo.com/testOutput/")
|
|
|
|
catalog_node.append(pkgNode)
|
|
|
|
|
|
|
|
if not os.path.isdir("testOutput2"):
|
|
|
|
os.mkdir("testOutput2")
|
|
|
|
|
|
|
|
cat_file = os.path.join("testOutput2", 'catalog_fragment.xml')
|
|
|
|
catalog_root.write(cat_file, encoding='utf-8', xml_declaration=True, pretty_print=True)
|
|
|
|
|
|
|
|
parsed = sgprops.readProps(cat_file)
|
|
|
|
parsedPkgNode = parsed.getChild("package")
|
|
|
|
|
|
|
|
self.assertEqual(parsedPkgNode.getValue('id'), pkg['id'])
|
|
|
|
self.assertEqual(parsedPkgNode.getValue('dir'), 'c150')
|
|
|
|
self.assertEqual(parsedPkgNode.getValue('url'), 'http://foo.com/testOutput/c150.zip')
|
|
|
|
self.assertFalse(parsedPkgNode.hasChild('thumbnail'))
|
|
|
|
self.assertFalse(parsedPkgNode.hasChild('thumbnail-path'));
|
|
|
|
|
|
|
|
self.assertEqual(parsedPkgNode.getValue('name'), pkg['name']);
|
|
|
|
self.assertFalse(parsedPkgNode.hasChild('description'));
|
|
|
|
self.assertFalse(parsedPkgNode.hasChild('author'));
|
|
|
|
self.assertFalse(parsedPkgNode.hasChild('minimum-fg-version'));
|
|
|
|
self.assertFalse(parsedPkgNode.hasChild('variant'));
|
2017-04-12 17:38:24 +08:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
unittest.main()
|