예제 #1
0
    def test_parse(self):
        num_precincts = 33
        num_candidates = 5
        # Overvotes and undervotes
        num_pseudo_candidates = 2
        num_expected_results = (num_candidates * (num_precincts + 1) +
                                num_pseudo_candidates * (num_precincts + 1))

        er = Parser()
        er.parse('tests/data/precinct.xml')

        self.assertEqual(er.timestamp.replace(tzinfo=None),
                         datetime.datetime(2014, 5, 20, 20, 19, 21))
        self.assertEqual(er.election_name, "2014 Primary Election")
        self.assertEqual(er.election_date, datetime.date(2014, 5, 20))
        self.assertEqual(er.region, "Greenup")
        self.assertEqual(er.total_voters, 28162)
        self.assertEqual(er.ballots_cast, 5926)
        self.assertEqual(er.voter_turnout, 21.04)

        self.assertEqual(len(er.result_jurisdictions), num_precincts)
        precinct = next(p for p in er.result_jurisdictions if p.name == 'A105')
        self.assertEqual(precinct.total_voters, 0)
        self.assertEqual(precinct.ballots_cast, 171)
        self.assertEqual(precinct.voter_turnout, 0)
        self.assertEqual(precinct.percent_reporting, 4)

        self.assertEqual(len(er.contests), 1)

        self.assertEqual(len(er.results), num_expected_results)
예제 #2
0
    def test_parse(self):
        num_counties = 75
        num_candidates = 1
        # Election
        num_vote_types = 4
        num_expected_results = (num_vote_types * num_counties * num_candidates
                                ) + (num_vote_types * num_candidates)

        er = Parser()
        er.parse('tests/data/county.xml')

        self.assertEqual(er.timestamp.replace(tzinfo=None),
                         datetime.datetime(2014, 11, 13, 14, 58, 41))
        self.assertEqual(er.election_name, "2014 General Election")
        self.assertEqual(er.election_date, datetime.date(2014, 11, 4))
        self.assertEqual(er.region, "AR")
        self.assertEqual(er.total_voters, 1690577)
        self.assertEqual(er.ballots_cast, 850615)
        self.assertEqual(er.voter_turnout, 50.32)

        self.assertEqual(len(er.result_jurisdictions), num_counties)
        county = next(c for c in er.result_jurisdictions
                      if c.name == 'Arkansas')
        self.assertEqual(county.total_voters, 10196)
        self.assertEqual(county.ballots_cast, 5137)
        self.assertEqual(county.voter_turnout, 50.38)
        self.assertEqual(county.precincts_participating, 30)
        self.assertEqual(county.precincts_reporting_percent, 100.0)

        self.assertEqual(len(er.contests), 1)

        self.assertEqual(len(er.results), num_expected_results)
예제 #3
0
    def test_parse(self):
        num_precincts = 33
        num_candidates = 5
        # Overvotes and undervotes
        num_pseudo_candidates = 2
        num_expected_results = (num_candidates * (num_precincts + 1) +
                num_pseudo_candidates * (num_precincts + 1))

        er = Parser()
        er.parse('tests/data/precinct.xml')

        self.assertEqual(er.timestamp.replace(tzinfo=None), datetime.datetime(2014, 5, 20, 20, 19, 21))
        self.assertEqual(er.election_name, "2014 Primary Election")
        self.assertEqual(er.election_date, datetime.date(2014, 5, 20))
        self.assertEqual(er.region, "Greenup")
        self.assertEqual(er.total_voters, 28162)
        self.assertEqual(er.ballots_cast, 5926)
        self.assertEqual(er.voter_turnout, 21.04)

        self.assertEqual(len(er.result_jurisdictions), num_precincts)
        precinct = next(p for p in er.result_jurisdictions if p.name == 'A105')
        self.assertEqual(precinct.total_voters, 0)
        self.assertEqual(precinct.ballots_cast, 171)
        self.assertEqual(precinct.voter_turnout, 0)
        self.assertEqual(precinct.percent_reporting, 4)

        self.assertEqual(len(er.contests), 1)

        self.assertEqual(len(er.results), num_expected_results)
예제 #4
0
    def test_parse(self):
        num_counties = 75
        num_candidates = 1
        # Election
        num_vote_types = 4
        num_expected_results = (num_vote_types * num_counties * num_candidates) + (num_vote_types * num_candidates)

        er = Parser()
        er.parse('tests/data/county.xml')

        self.assertEqual(er.timestamp.replace(tzinfo=None), datetime.datetime(2014, 11, 13, 14, 58, 41))
        self.assertEqual(er.election_name, "2014 General Election")
        self.assertEqual(er.election_date, datetime.date(2014, 11, 4))
        self.assertEqual(er.region, "AR")
        self.assertEqual(er.total_voters, 1690577)
        self.assertEqual(er.ballots_cast, 850615)
        self.assertEqual(er.voter_turnout, 50.32)

        self.assertEqual(len(er.result_jurisdictions), num_counties)
        county = next(c for c in er.result_jurisdictions if c.name == 'Arkansas')
        self.assertEqual(county.total_voters, 10196)
        self.assertEqual(county.ballots_cast, 5137)
        self.assertEqual(county.voter_turnout, 50.38)
        self.assertEqual(county.precincts_participating, 30)
        self.assertEqual(county.precincts_reporting_percent, 100.0)

        self.assertEqual(len(er.contests), 1)

        self.assertEqual(len(er.results), num_expected_results)
예제 #5
0
    def test__get_or_create_result_jurisdiction(self):
        result_jurisdiction_name = "Test"
        result_jurisdiction_element = lxml.etree.Element(
            "County", {"name": result_jurisdiction_name})
        result_jurisdiction = Parser._parse_result_jurisdiction(
            result_jurisdiction_element)

        parser = Parser()

        self.assertEqual(parser._result_jurisdictions, [])
        self.assertEqual(parser._result_jurisdiction_lookup, {})

        # Test the "create" part.
        parser._get_or_create_result_jurisdiction(result_jurisdiction_element)

        self.assertEqual(parser._result_jurisdictions, [result_jurisdiction])
        self.assertEqual(parser._result_jurisdiction_lookup,
                         {result_jurisdiction_name: result_jurisdiction})

        # Test the "get" part.
        parser._get_or_create_result_jurisdiction(result_jurisdiction_element)

        self.assertEqual(parser._result_jurisdictions, [result_jurisdiction])
        self.assertEqual(parser._result_jurisdiction_lookup,
                         {result_jurisdiction_name: result_jurisdiction})
예제 #6
0
 def test__underscore_to_camel(self):
     self.assertEqual(Parser._underscore_to_camel(""), "")
     self.assertEqual(Parser._underscore_to_camel("test"), "test")
     self.assertEqual(Parser._underscore_to_camel("test_again"), "testAgain")
     self.assertEqual(Parser._underscore_to_camel("test_again_but_longer"), "testAgainButLonger")
     self.assertEqual(Parser._underscore_to_camel("_test_again"), "TestAgain")  # XXX: Is this what we expect?
     self.assertEqual(Parser._underscore_to_camel("testing_123"), "testing123")
     self.assertEqual(Parser._underscore_to_camel("testing_123_again"), "testing123Again")
예제 #7
0
    def test_add_result_jurisdiction(self):
        result_jurisdiction_name = "Test"
        result_jurisdiction = ResultJurisdiction(
            name=result_jurisdiction_name,
            total_voters=0,
            ballots_cast=0,
            voter_turnout=100.0,
            percent_reporting=100.0,
            precincts_participating=0,
            precincts_reported=0,
            precincts_reporting_percent=100.0,
            level="county",
        )

        parser = Parser()

        self.assertEqual(parser._result_jurisdictions, [])
        self.assertEqual(parser._result_jurisdiction_lookup, {})

        parser.add_result_jurisdiction(result_jurisdiction)

        self.assertEqual(parser._result_jurisdictions, [ result_jurisdiction ])
        self.assertEqual(parser._result_jurisdiction_lookup, { result_jurisdiction_name: result_jurisdiction })
예제 #8
0
 def test__underscore_to_camel(self):
     self.assertEqual(Parser._underscore_to_camel(""), "")
     self.assertEqual(Parser._underscore_to_camel("test"), "test")
     self.assertEqual(Parser._underscore_to_camel("test_again"),
                      "testAgain")
     self.assertEqual(Parser._underscore_to_camel("test_again_but_longer"),
                      "testAgainButLonger")
     self.assertEqual(Parser._underscore_to_camel("_test_again"),
                      "TestAgain")  # XXX: Is this what we expect?
     self.assertEqual(Parser._underscore_to_camel("testing_123"),
                      "testing123")
     self.assertEqual(Parser._underscore_to_camel("testing_123_again"),
                      "testing123Again")
예제 #9
0
    def test_add_result_jurisdiction(self):
        result_jurisdiction_name = "Test"
        result_jurisdiction = ResultJurisdiction(
            name=result_jurisdiction_name,
            total_voters=0,
            ballots_cast=0,
            voter_turnout=100.0,
            percent_reporting=100.0,
            precincts_participating=0,
            precincts_reported=0,
            precincts_reporting_percent=100.0,
            level="county",
        )

        parser = Parser()

        self.assertEqual(parser._result_jurisdictions, [])
        self.assertEqual(parser._result_jurisdiction_lookup, {})

        parser.add_result_jurisdiction(result_jurisdiction)

        self.assertEqual(parser._result_jurisdictions, [result_jurisdiction])
        self.assertEqual(parser._result_jurisdiction_lookup,
                         {result_jurisdiction_name: result_jurisdiction})
예제 #10
0
    def test__parse_result_jurisdiction(self):
        tag_name = "County"
        attributes = {
            "name": "Arkansas",
            "totalVoters": "10196",
            "ballotsCast": "5137",
            "voterTurnout": "50.38",
            "percentReporting": "100.00",
            "precinctsParticipating": "30",
            "precinctsReported": "30",
            "precinctsReportingPercent": "100.00",
        }

        result_jurisdiction_element = lxml.etree.Element(tag_name, attributes)

        result_jurisdiction = Parser._parse_result_jurisdiction(
            result_jurisdiction_element)

        self.assertIsInstance(result_jurisdiction, ResultJurisdiction)

        self.assertTrue(hasattr(result_jurisdiction, "level"))
        self.assertTrue(hasattr(result_jurisdiction, "name"))
        self.assertTrue(hasattr(result_jurisdiction, "total_voters"))
        self.assertTrue(hasattr(result_jurisdiction, "ballots_cast"))
        self.assertTrue(hasattr(result_jurisdiction, "voter_turnout"))
        self.assertTrue(hasattr(result_jurisdiction, "percent_reporting"))
        self.assertTrue(hasattr(result_jurisdiction,
                                "precincts_participating"))
        self.assertTrue(hasattr(result_jurisdiction, "precincts_reported"))
        self.assertTrue(
            hasattr(result_jurisdiction, "precincts_reporting_percent"))

        self.assertEqual(result_jurisdiction.level, tag_name.lower())
        self.assertEqual(result_jurisdiction.name, attributes["name"])
        self.assertEqual(result_jurisdiction.total_voters,
                         int(attributes["totalVoters"]))
        self.assertEqual(result_jurisdiction.ballots_cast,
                         int(attributes["ballotsCast"]))
        self.assertEqual(result_jurisdiction.voter_turnout,
                         float(attributes["voterTurnout"]))
        self.assertEqual(result_jurisdiction.percent_reporting,
                         float(attributes["percentReporting"]))
        self.assertEqual(result_jurisdiction.precincts_participating,
                         float(attributes["precinctsParticipating"]))
        self.assertEqual(result_jurisdiction.precincts_reported,
                         float(attributes["precinctsReported"]))
        self.assertEqual(result_jurisdiction.precincts_reporting_percent,
                         float(attributes["precinctsReportingPercent"]))
예제 #11
0
    def test__parse_result_jurisdiction(self):
        tag_name = "County"
        attributes = {
            "name": "Arkansas",
            "totalVoters": "10196",
            "ballotsCast": "5137",
            "voterTurnout": "50.38",
            "percentReporting": "100.00",
            "precinctsParticipating": "30",
            "precinctsReported": "30",
            "precinctsReportingPercent": "100.00",
        }

        result_jurisdiction_element = lxml.etree.Element(tag_name, attributes)

        result_jurisdiction = Parser._parse_result_jurisdiction(result_jurisdiction_element)

        self.assertIsInstance(result_jurisdiction, ResultJurisdiction)

        self.assertTrue(hasattr(result_jurisdiction, "level"))
        self.assertTrue(hasattr(result_jurisdiction, "name"))
        self.assertTrue(hasattr(result_jurisdiction, "total_voters"))
        self.assertTrue(hasattr(result_jurisdiction, "ballots_cast"))
        self.assertTrue(hasattr(result_jurisdiction, "voter_turnout"))
        self.assertTrue(hasattr(result_jurisdiction, "percent_reporting"))
        self.assertTrue(hasattr(result_jurisdiction, "precincts_participating"))
        self.assertTrue(hasattr(result_jurisdiction, "precincts_reported"))
        self.assertTrue(hasattr(result_jurisdiction, "precincts_reporting_percent"))

        self.assertEqual(result_jurisdiction.level, tag_name.lower())
        self.assertEqual(result_jurisdiction.name, attributes["name"])
        self.assertEqual(result_jurisdiction.total_voters, int(attributes["totalVoters"]))
        self.assertEqual(result_jurisdiction.ballots_cast, int(attributes["ballotsCast"]))
        self.assertEqual(result_jurisdiction.voter_turnout, float(attributes["voterTurnout"]))
        self.assertEqual(result_jurisdiction.percent_reporting, float(attributes["percentReporting"]))
        self.assertEqual(result_jurisdiction.precincts_participating, float(attributes["precinctsParticipating"]))
        self.assertEqual(result_jurisdiction.precincts_reported, float(attributes["precinctsReported"]))
        self.assertEqual(result_jurisdiction.precincts_reporting_percent, float(attributes["precinctsReportingPercent"]))
예제 #12
0
    def test__get_or_create_result_jurisdiction(self):
        result_jurisdiction_name = "Test"
        result_jurisdiction_element = lxml.etree.Element("County", { "name": result_jurisdiction_name })
        result_jurisdiction = Parser._parse_result_jurisdiction(result_jurisdiction_element)

        parser = Parser()

        self.assertEqual(parser._result_jurisdictions, [])
        self.assertEqual(parser._result_jurisdiction_lookup, {})

        # Test the "create" part.
        parser._get_or_create_result_jurisdiction(result_jurisdiction_element)

        self.assertEqual(parser._result_jurisdictions, [ result_jurisdiction ])
        self.assertEqual(parser._result_jurisdiction_lookup, { result_jurisdiction_name: result_jurisdiction })

        # Test the "get" part.
        parser._get_or_create_result_jurisdiction(result_jurisdiction_element)

        self.assertEqual(parser._result_jurisdictions, [ result_jurisdiction ])
        self.assertEqual(parser._result_jurisdiction_lookup, { result_jurisdiction_name: result_jurisdiction })
예제 #13
0
    def test_parse(self):
        num_counties = 75
        num_candidates = 1
        # Election
        num_vote_types = 4
        num_expected_results = (
            (num_vote_types * num_counties * num_candidates) +
            (num_vote_types * num_candidates))

        er = Parser()
        er.parse('tests/data/county.xml')

        self.assertEqual(er.timestamp.replace(tzinfo=None),
                         datetime.datetime(2014, 11, 13, 14, 58, 41))
        self.assertEqual(er.election_name, "2014 General Election")
        self.assertEqual(er.election_date, datetime.date(2014, 11, 4))
        self.assertEqual(er.region, "AR")
        self.assertEqual(er.total_voters, 1690577)
        self.assertEqual(er.ballots_cast, 850615)
        self.assertEqual(er.voter_turnout, 50.32)

        self.assertEqual(len(er.result_jurisdictions), num_counties)
        county = next(c for c in er.result_jurisdictions
                      if c.name == 'Arkansas')
        self.assertEqual(county.total_voters, 10196)
        self.assertEqual(county.ballots_cast, 5137)
        self.assertEqual(county.voter_turnout, 50.38)
        self.assertEqual(county.precincts_participating, 30)
        self.assertEqual(county.precincts_reporting_percent, 100.0)

        self.assertEqual(len(er.contests), 1)

        self.assertEqual(len(er.results), num_expected_results)

        result_jurisdiction_name = "Arkansas"
        result_jurisdiction = er.get_result_jurisdiction(
            result_jurisdiction_name)

        self.assertEqual(str(result_jurisdiction), result_jurisdiction_name)
        self.assertEqual(result_jurisdiction.name, result_jurisdiction_name)
        self.assertEqual(result_jurisdiction.total_voters, 10196)
        self.assertEqual(result_jurisdiction.ballots_cast, 5137)
        self.assertEqual(result_jurisdiction.voter_turnout, 50.38)
        self.assertEqual(result_jurisdiction.precincts_participating, 30)
        self.assertEqual(result_jurisdiction.precincts_reported, 30)
        self.assertEqual(result_jurisdiction.precincts_reporting_percent,
                         100.0)

        self.assertEqual(result_jurisdiction, county)

        contest_text = "U.S. Senate"
        contest = er.get_contest(contest_text)

        self.assertEqual(str(contest), contest_text)
        self.assertEqual(contest.text, contest_text)
        self.assertEqual(contest.key, "100")
        self.assertEqual(contest.vote_for, 1)
        self.assertFalse(contest.is_question)
        self.assertEqual(contest.counties_participating, 75)
        self.assertEqual(contest.counties_reported, 75)
        self.assertEqual(contest.precincts_participating, 2655)
        self.assertEqual(contest.precincts_reported, 2655)

        contest_choice_text = "Tom Cotton"
        contest_choice = contest.choices[0]

        self.assertEqual(contest_choice.contest, contest)

        self.assertEqual(str(contest_choice), contest_choice_text)
        self.assertEqual(contest_choice.text, contest_choice_text)
        self.assertEqual(contest_choice.key, "001")
        self.assertEqual(contest_choice.party, "REP")
        self.assertEqual(contest_choice.total_votes, 477734)
예제 #14
0
    def test_parse(self):
        num_precincts = 33
        num_candidates = 5
        # Overvotes and undervotes
        num_pseudo_candidates = 2
        num_expected_results = (num_candidates * (num_precincts + 1) +
                                num_pseudo_candidates * (num_precincts + 1))

        er = Parser()
        er.parse('tests/data/precinct.xml')

        self.assertEqual(er.timestamp.replace(tzinfo=None),
                         datetime.datetime(2014, 5, 20, 20, 19, 21))
        self.assertEqual(er.election_name, "2014 Primary Election")
        self.assertEqual(er.election_date, datetime.date(2014, 5, 20))
        self.assertEqual(er.region, "Greenup")
        self.assertEqual(er.total_voters, 28162)
        self.assertEqual(er.ballots_cast, 5926)
        self.assertEqual(er.voter_turnout, 21.04)

        self.assertEqual(len(er.result_jurisdictions), num_precincts)
        precinct = next(p for p in er.result_jurisdictions if p.name == 'A105')
        self.assertEqual(precinct.total_voters, 0)
        self.assertEqual(precinct.ballots_cast, 171)
        self.assertEqual(precinct.voter_turnout, 0)
        self.assertEqual(precinct.percent_reporting, 4)

        self.assertEqual(len(er.contests), 1)

        self.assertEqual(len(er.results), num_expected_results)

        result_jurisdiction_name = "A105"
        result_jurisdiction = er.get_result_jurisdiction(
            result_jurisdiction_name)

        self.assertEqual(str(result_jurisdiction), result_jurisdiction_name)
        self.assertEqual(result_jurisdiction.name, result_jurisdiction_name)
        self.assertEqual(result_jurisdiction.total_voters, 0)
        self.assertEqual(result_jurisdiction.ballots_cast, 171)
        self.assertEqual(result_jurisdiction.voter_turnout, 0)
        self.assertEqual(result_jurisdiction.percent_reporting, 4)

        self.assertEqual(result_jurisdiction, precinct)

        contest_text = "US Senator - REPUBLICAN"
        contest = er.get_contest(contest_text)

        self.assertEqual(str(contest), contest_text)
        self.assertEqual(contest.text, contest_text)
        self.assertEqual(contest.key, "4")
        self.assertEqual(contest.vote_for, 1)
        self.assertFalse(contest.is_question)
        self.assertEqual(contest.precincts_reporting, 32)
        self.assertEqual(contest.precincts_reported, 32)

        contest_choice_text = "Matt BEVIN"
        contest_choice = contest.choices[0]

        self.assertEqual(contest_choice.contest, contest)

        self.assertEqual(str(contest_choice), contest_choice_text)
        self.assertEqual(contest_choice.text, contest_choice_text)
        self.assertEqual(contest_choice.key, "1")
        self.assertEqual(contest_choice.total_votes, 820)
예제 #15
0
    def test_parse(self):
        num_counties = 75
        num_candidates = 1
        # Election
        num_vote_types = 4
        num_expected_results = (
            (num_vote_types * num_counties * num_candidates) +
            (num_vote_types * num_candidates)
        )

        er = Parser()
        er.parse('tests/data/county.xml')

        self.assertEqual(er.timestamp.replace(tzinfo=None), datetime.datetime(2014, 11, 13, 14, 58, 41))
        self.assertEqual(er.election_name, "2014 General Election")
        self.assertEqual(er.election_date, datetime.date(2014, 11, 4))
        self.assertEqual(er.region, "AR")
        self.assertEqual(er.total_voters, 1690577)
        self.assertEqual(er.ballots_cast, 850615)
        self.assertEqual(er.voter_turnout, 50.32)

        self.assertEqual(len(er.result_jurisdictions), num_counties)
        county = next(c for c in er.result_jurisdictions if c.name == 'Arkansas')
        self.assertEqual(county.total_voters, 10196)
        self.assertEqual(county.ballots_cast, 5137)
        self.assertEqual(county.voter_turnout, 50.38)
        self.assertEqual(county.precincts_participating, 30)
        self.assertEqual(county.precincts_reporting_percent, 100.0)

        self.assertEqual(len(er.contests), 1)

        self.assertEqual(len(er.results), num_expected_results)

        result_jurisdiction_name = "Arkansas"
        result_jurisdiction = er.get_result_jurisdiction(result_jurisdiction_name)

        self.assertEqual(str(result_jurisdiction), result_jurisdiction_name)
        self.assertEqual(result_jurisdiction.name, result_jurisdiction_name)
        self.assertEqual(result_jurisdiction.total_voters, 10196)
        self.assertEqual(result_jurisdiction.ballots_cast, 5137)
        self.assertEqual(result_jurisdiction.voter_turnout, 50.38)
        self.assertEqual(result_jurisdiction.precincts_participating, 30)
        self.assertEqual(result_jurisdiction.precincts_reported, 30)
        self.assertEqual(result_jurisdiction.precincts_reporting_percent, 100.0)

        self.assertEqual(result_jurisdiction, county)

        contest_text = "U.S. Senate"
        contest = er.get_contest(contest_text)

        self.assertEqual(str(contest), contest_text)
        self.assertEqual(contest.text, contest_text)
        self.assertEqual(contest.key, "100")
        self.assertEqual(contest.vote_for, 1)
        self.assertFalse(contest.is_question)
        self.assertEqual(contest.counties_participating, 75)
        self.assertEqual(contest.counties_reported, 75)
        self.assertEqual(contest.precincts_participating, 2655)
        self.assertEqual(contest.precincts_reported, 2655)

        contest_choice_text = "Tom Cotton"
        contest_choice = contest.choices[0]

        self.assertEqual(contest_choice.contest, contest)

        self.assertEqual(str(contest_choice), contest_choice_text)
        self.assertEqual(contest_choice.text, contest_choice_text)
        self.assertEqual(contest_choice.key, "001")
        self.assertEqual(contest_choice.party, "REP")
        self.assertEqual(contest_choice.total_votes, 477734)
예제 #16
0
    def test_parse(self):
        num_precincts = 33
        num_candidates = 5
        # Overvotes and undervotes
        num_pseudo_candidates = 2
        num_expected_results = (
            num_candidates * (num_precincts + 1) +
            num_pseudo_candidates * (num_precincts + 1)
        )

        er = Parser()
        er.parse('tests/data/precinct.xml')

        self.assertEqual(er.timestamp.replace(tzinfo=None), datetime.datetime(2014, 5, 20, 20, 19, 21))
        self.assertEqual(er.election_name, "2014 Primary Election")
        self.assertEqual(er.election_date, datetime.date(2014, 5, 20))
        self.assertEqual(er.region, "Greenup")
        self.assertEqual(er.total_voters, 28162)
        self.assertEqual(er.ballots_cast, 5926)
        self.assertEqual(er.voter_turnout, 21.04)

        self.assertEqual(len(er.result_jurisdictions), num_precincts)
        precinct = next(p for p in er.result_jurisdictions if p.name == 'A105')
        self.assertEqual(precinct.total_voters, 0)
        self.assertEqual(precinct.ballots_cast, 171)
        self.assertEqual(precinct.voter_turnout, 0)
        self.assertEqual(precinct.percent_reporting, 4)

        self.assertEqual(len(er.contests), 1)

        self.assertEqual(len(er.results), num_expected_results)

        result_jurisdiction_name = "A105"
        result_jurisdiction = er.get_result_jurisdiction(result_jurisdiction_name)

        self.assertEqual(str(result_jurisdiction), result_jurisdiction_name)
        self.assertEqual(result_jurisdiction.name, result_jurisdiction_name)
        self.assertEqual(result_jurisdiction.total_voters, 0)
        self.assertEqual(result_jurisdiction.ballots_cast, 171)
        self.assertEqual(result_jurisdiction.voter_turnout, 0)
        self.assertEqual(result_jurisdiction.percent_reporting, 4)

        self.assertEqual(result_jurisdiction, precinct)

        contest_text = "US Senator - REPUBLICAN"
        contest = er.get_contest(contest_text)

        self.assertEqual(str(contest), contest_text)
        self.assertEqual(contest.text, contest_text)
        self.assertEqual(contest.key, "4")
        self.assertEqual(contest.vote_for, 1)
        self.assertFalse(contest.is_question)
        self.assertEqual(contest.precincts_reporting, 32)
        self.assertEqual(contest.precincts_reported, 32)

        contest_choice_text = "Matt BEVIN"
        contest_choice = contest.choices[0]

        self.assertEqual(contest_choice.contest, contest)

        self.assertEqual(str(contest_choice), contest_choice_text)
        self.assertEqual(contest_choice.text, contest_choice_text)
        self.assertEqual(contest_choice.key, "1")
        self.assertEqual(contest_choice.total_votes, 820)