Repository URL to install this package:
|
Version:
4.0.0 ▾
|
#!/usr/bin/env python
# -*- coding: utf-8 -*-
#
# Generated from FHIR 4.0.0-a53ec6ee1b on 2019-05-07.
# 2019, SMART Health IT.
import os
import io
import unittest
import json
from . import immunization
from .fhirdate import FHIRDate
class ImmunizationTests(unittest.TestCase):
def instantiate_from(self, filename):
datadir = os.environ.get('FHIR_UNITTEST_DATADIR') or ''
with io.open(os.path.join(datadir, filename), 'r', encoding='utf-8') as handle:
js = json.load(handle)
self.assertEqual("Immunization", js["resourceType"])
return immunization.Immunization(js)
def testImmunization1(self):
inst = self.instantiate_from("immunization-example.json")
self.assertIsNotNone(inst, "Must have instantiated a Immunization instance")
self.implImmunization1(inst)
js = inst.as_json()
self.assertEqual("Immunization", js["resourceType"])
inst2 = immunization.Immunization(js)
self.implImmunization1(inst2)
def implImmunization1(self, inst):
self.assertEqual(inst.doseQuantity.code, "mg")
self.assertEqual(inst.doseQuantity.system, "http://unitsofmeasure.org")
self.assertEqual(inst.doseQuantity.value, 5)
self.assertEqual(inst.education[0].documentType, "253088698300010311120702")
self.assertEqual(inst.education[0].presentationDate.date, FHIRDate("2013-01-10").date)
self.assertEqual(inst.education[0].presentationDate.as_json(), "2013-01-10")
self.assertEqual(inst.education[0].publicationDate.date, FHIRDate("2012-07-02").date)
self.assertEqual(inst.education[0].publicationDate.as_json(), "2012-07-02")
self.assertEqual(inst.expirationDate.date, FHIRDate("2015-02-15").date)
self.assertEqual(inst.expirationDate.as_json(), "2015-02-15")
self.assertEqual(inst.fundingSource.coding[0].code, "private")
self.assertEqual(inst.fundingSource.coding[0].system, "http://terminology.hl7.org/CodeSystem/immunization-funding-source")
self.assertEqual(inst.id, "example")
self.assertEqual(inst.identifier[0].system, "urn:ietf:rfc:3986")
self.assertEqual(inst.identifier[0].value, "urn:oid:1.3.6.1.4.1.21367.2005.3.7.1234")
self.assertTrue(inst.isSubpotent)
self.assertEqual(inst.lotNumber, "AAJN11K")
self.assertEqual(inst.meta.tag[0].code, "HTEST")
self.assertEqual(inst.meta.tag[0].display, "test health data")
self.assertEqual(inst.meta.tag[0].system, "http://terminology.hl7.org/CodeSystem/v3-ActReason")
self.assertEqual(inst.note[0].text, "Notes on adminstration of vaccine")
self.assertEqual(inst.occurrenceDateTime.date, FHIRDate("2013-01-10").date)
self.assertEqual(inst.occurrenceDateTime.as_json(), "2013-01-10")
self.assertEqual(inst.performer[0].function.coding[0].code, "OP")
self.assertEqual(inst.performer[0].function.coding[0].system, "http://terminology.hl7.org/CodeSystem/v2-0443")
self.assertEqual(inst.performer[1].function.coding[0].code, "AP")
self.assertEqual(inst.performer[1].function.coding[0].system, "http://terminology.hl7.org/CodeSystem/v2-0443")
self.assertTrue(inst.primarySource)
self.assertEqual(inst.programEligibility[0].coding[0].code, "ineligible")
self.assertEqual(inst.programEligibility[0].coding[0].system, "http://terminology.hl7.org/CodeSystem/immunization-program-eligibility")
self.assertEqual(inst.reasonCode[0].coding[0].code, "429060002")
self.assertEqual(inst.reasonCode[0].coding[0].system, "http://snomed.info/sct")
self.assertEqual(inst.route.coding[0].code, "IM")
self.assertEqual(inst.route.coding[0].display, "Injection, intramuscular")
self.assertEqual(inst.route.coding[0].system, "http://terminology.hl7.org/CodeSystem/v3-RouteOfAdministration")
self.assertEqual(inst.site.coding[0].code, "LA")
self.assertEqual(inst.site.coding[0].display, "left arm")
self.assertEqual(inst.site.coding[0].system, "http://terminology.hl7.org/CodeSystem/v3-ActSite")
self.assertEqual(inst.status, "completed")
self.assertEqual(inst.text.status, "generated")
self.assertEqual(inst.vaccineCode.coding[0].code, "FLUVAX")
self.assertEqual(inst.vaccineCode.coding[0].system, "urn:oid:1.2.36.1.2001.1005.17")
self.assertEqual(inst.vaccineCode.text, "Fluvax (Influenza)")
def testImmunization2(self):
inst = self.instantiate_from("immunization-example-historical.json")
self.assertIsNotNone(inst, "Must have instantiated a Immunization instance")
self.implImmunization2(inst)
js = inst.as_json()
self.assertEqual("Immunization", js["resourceType"])
inst2 = immunization.Immunization(js)
self.implImmunization2(inst2)
def implImmunization2(self, inst):
self.assertEqual(inst.id, "historical")
self.assertEqual(inst.identifier[0].system, "urn:ietf:rfc:3986")
self.assertEqual(inst.identifier[0].value, "urn:oid:1.3.6.1.4.1.21367.2005.3.7.1234")
self.assertEqual(inst.meta.tag[0].code, "HTEST")
self.assertEqual(inst.meta.tag[0].display, "test health data")
self.assertEqual(inst.meta.tag[0].system, "http://terminology.hl7.org/CodeSystem/v3-ActReason")
self.assertEqual(inst.note[0].text, "Notes on adminstration of a historical vaccine")
self.assertEqual(inst.occurrenceString, "January 2012")
self.assertFalse(inst.primarySource)
self.assertEqual(inst.reportOrigin.coding[0].code, "record")
self.assertEqual(inst.reportOrigin.coding[0].system, "http://terminology.hl7.org/CodeSystem/immunization-origin")
self.assertEqual(inst.reportOrigin.text, "Written Record")
self.assertEqual(inst.status, "completed")
self.assertEqual(inst.text.status, "generated")
self.assertEqual(inst.vaccineCode.coding[0].code, "GNFLU")
self.assertEqual(inst.vaccineCode.coding[0].system, "urn:oid:1.2.36.1.2001.1005.17")
self.assertEqual(inst.vaccineCode.text, "Influenza")
def testImmunization3(self):
inst = self.instantiate_from("immunization-example-protocol.json")
self.assertIsNotNone(inst, "Must have instantiated a Immunization instance")
self.implImmunization3(inst)
js = inst.as_json()
self.assertEqual("Immunization", js["resourceType"])
inst2 = immunization.Immunization(js)
self.implImmunization3(inst2)
def implImmunization3(self, inst):
self.assertEqual(inst.doseQuantity.code, "mg")
self.assertEqual(inst.doseQuantity.system, "http://unitsofmeasure.org")
self.assertEqual(inst.doseQuantity.value, 5)
self.assertEqual(inst.expirationDate.date, FHIRDate("2018-12-15").date)
self.assertEqual(inst.expirationDate.as_json(), "2018-12-15")
self.assertEqual(inst.fundingSource.coding[0].code, "private")
self.assertEqual(inst.fundingSource.coding[0].system, "http://terminology.hl7.org/CodeSystem/immunization-funding-source")
self.assertEqual(inst.id, "protocol")
self.assertEqual(inst.identifier[0].system, "urn:ietf:rfc:3986")
self.assertEqual(inst.identifier[0].value, "urn:oid:1.3.6.1.4.1.21367.2005.3.7.1234")
self.assertFalse(inst.isSubpotent)
self.assertEqual(inst.lotNumber, "PT123F")
self.assertEqual(inst.meta.tag[0].code, "HTEST")
self.assertEqual(inst.meta.tag[0].display, "test health data")
self.assertEqual(inst.meta.tag[0].system, "http://terminology.hl7.org/CodeSystem/v3-ActReason")
self.assertEqual(inst.occurrenceDateTime.date, FHIRDate("2018-06-18").date)
self.assertEqual(inst.occurrenceDateTime.as_json(), "2018-06-18")
self.assertEqual(inst.performer[0].function.coding[0].code, "OP")
self.assertEqual(inst.performer[0].function.coding[0].system, "http://terminology.hl7.org/CodeSystem/v2-0443")
self.assertEqual(inst.performer[1].function.coding[0].code, "AP")
self.assertEqual(inst.performer[1].function.coding[0].system, "http://terminology.hl7.org/CodeSystem/v2-0443")
self.assertTrue(inst.primarySource)
self.assertEqual(inst.programEligibility[0].coding[0].code, "ineligible")
self.assertEqual(inst.programEligibility[0].coding[0].system, "http://terminology.hl7.org/CodeSystem/immunization-program-eligibility")
self.assertEqual(inst.protocolApplied[0].doseNumberPositiveInt, 1)
self.assertEqual(inst.protocolApplied[0].series, "2-dose")
self.assertEqual(inst.protocolApplied[0].targetDisease[0].coding[0].code, "40468003")
self.assertEqual(inst.protocolApplied[0].targetDisease[0].coding[0].system, "http://snomed.info/sct")
self.assertEqual(inst.protocolApplied[1].doseNumberPositiveInt, 2)
self.assertEqual(inst.protocolApplied[1].series, "3-dose")
self.assertEqual(inst.protocolApplied[1].targetDisease[0].coding[0].code, "66071002")
self.assertEqual(inst.protocolApplied[1].targetDisease[0].coding[0].system, "http://snomed.info/sct")
self.assertEqual(inst.route.coding[0].code, "IM")
self.assertEqual(inst.route.coding[0].display, "Injection, intramuscular")
self.assertEqual(inst.route.coding[0].system, "http://terminology.hl7.org/CodeSystem/v3-RouteOfAdministration")
self.assertEqual(inst.site.coding[0].code, "LA")
self.assertEqual(inst.site.coding[0].display, "left arm")
self.assertEqual(inst.site.coding[0].system, "http://terminology.hl7.org/CodeSystem/v3-ActSite")
self.assertEqual(inst.status, "completed")
self.assertEqual(inst.text.status, "generated")
self.assertEqual(inst.vaccineCode.coding[0].code, "104")
self.assertEqual(inst.vaccineCode.coding[0].system, "http://hl7.org/fhir/sid/cvx")
self.assertEqual(inst.vaccineCode.text, "Twinrix (HepA/HepB)")
def testImmunization4(self):
inst = self.instantiate_from("immunization-example-refused.json")
self.assertIsNotNone(inst, "Must have instantiated a Immunization instance")
self.implImmunization4(inst)
js = inst.as_json()
self.assertEqual("Immunization", js["resourceType"])
inst2 = immunization.Immunization(js)
self.implImmunization4(inst2)
def implImmunization4(self, inst):
self.assertEqual(inst.id, "notGiven")
self.assertEqual(inst.meta.tag[0].code, "HTEST")
self.assertEqual(inst.meta.tag[0].display, "test health data")
self.assertEqual(inst.meta.tag[0].system, "http://terminology.hl7.org/CodeSystem/v3-ActReason")
self.assertEqual(inst.occurrenceDateTime.date, FHIRDate("2013-01-10").date)
self.assertEqual(inst.occurrenceDateTime.as_json(), "2013-01-10")
self.assertTrue(inst.primarySource)
self.assertEqual(inst.status, "not-done")
self.assertEqual(inst.statusReason.coding[0].code, "MEDPREC")
self.assertEqual(inst.statusReason.coding[0].display, "medical precaution")
self.assertEqual(inst.statusReason.coding[0].system, "http://terminology.hl7.org/CodeSystem/v3-ActReason")
self.assertEqual(inst.text.status, "generated")
self.assertEqual(inst.vaccineCode.coding[0].code, "01")
self.assertEqual(inst.vaccineCode.coding[0].display, "DTP")
self.assertEqual(inst.vaccineCode.coding[0].system, "http://hl7.org/fhir/sid/cvx")
def testImmunization5(self):
inst = self.instantiate_from("immunization-example-subpotent.json")
self.assertIsNotNone(inst, "Must have instantiated a Immunization instance")
self.implImmunization5(inst)
js = inst.as_json()
self.assertEqual("Immunization", js["resourceType"])
inst2 = immunization.Immunization(js)
self.implImmunization5(inst2)
def implImmunization5(self, inst):
self.assertEqual(inst.doseQuantity.code, "ml")
self.assertEqual(inst.doseQuantity.system, "http://unitsofmeasure.org")
self.assertEqual(inst.doseQuantity.value, 0.5)
self.assertEqual(inst.education[0].documentType, "253088698300010311120702")
self.assertEqual(inst.education[0].presentationDate.date, FHIRDate("2013-01-10").date)
self.assertEqual(inst.education[0].presentationDate.as_json(), "2013-01-10")
self.assertEqual(inst.education[0].publicationDate.date, FHIRDate("2012-07-02").date)
self.assertEqual(inst.education[0].publicationDate.as_json(), "2012-07-02")
self.assertEqual(inst.expirationDate.date, FHIRDate("2015-02-28").date)
self.assertEqual(inst.expirationDate.as_json(), "2015-02-28")
self.assertEqual(inst.fundingSource.coding[0].code, "private")
self.assertEqual(inst.fundingSource.coding[0].system, "http://terminology.hl7.org/CodeSystem/immunization-funding-source")
self.assertEqual(inst.id, "subpotent")
self.assertEqual(inst.identifier[0].system, "urn:ietf:rfc:3986")
self.assertEqual(inst.identifier[0].value, "urn:oid:1.3.6.1.4.1.21367.2005.3.7.1234")
self.assertFalse(inst.isSubpotent)
self.assertEqual(inst.lotNumber, "AAJN11K")
self.assertEqual(inst.meta.tag[0].code, "HTEST")
self.assertEqual(inst.meta.tag[0].display, "test health data")
self.assertEqual(inst.meta.tag[0].system, "http://terminology.hl7.org/CodeSystem/v3-ActReason")
self.assertEqual(inst.note[0].text, "Notes on adminstration of vaccine")
self.assertEqual(inst.occurrenceDateTime.date, FHIRDate("2015-01-15").date)
self.assertEqual(inst.occurrenceDateTime.as_json(), "2015-01-15")
self.assertEqual(inst.performer[0].function.coding[0].code, "OP")
self.assertEqual(inst.performer[0].function.coding[0].system, "http://terminology.hl7.org/CodeSystem/v2-0443")
self.assertEqual(inst.performer[1].function.coding[0].code, "AP")
self.assertEqual(inst.performer[1].function.coding[0].system, "http://terminology.hl7.org/CodeSystem/v2-0443")
self.assertTrue(inst.primarySource)
self.assertEqual(inst.programEligibility[0].coding[0].code, "ineligible")
self.assertEqual(inst.programEligibility[0].coding[0].system, "http://terminology.hl7.org/CodeSystem/immunization-program-eligibility")
self.assertEqual(inst.route.coding[0].code, "IM")
self.assertEqual(inst.route.coding[0].display, "Injection, intramuscular")
self.assertEqual(inst.route.coding[0].system, "http://terminology.hl7.org/CodeSystem/v3-RouteOfAdministration")
self.assertEqual(inst.site.coding[0].code, "LT")
self.assertEqual(inst.site.coding[0].display, "left thigh")
self.assertEqual(inst.site.coding[0].system, "http://terminology.hl7.org/CodeSystem/v3-ActSite")
self.assertEqual(inst.status, "completed")
self.assertEqual(inst.subpotentReason[0].coding[0].code, "partial")
self.assertEqual(inst.subpotentReason[0].coding[0].system, "http://terminology.hl7.org/CodeSystem/immunization-subpotent-reason")
self.assertEqual(inst.text.status, "generated")
self.assertEqual(inst.vaccineCode.coding[0].code, "GNHEP")
self.assertEqual(inst.vaccineCode.coding[0].system, "urn:oid:1.2.36.1.2001.1005.17")
self.assertEqual(inst.vaccineCode.text, "Hepatitis B")