sapor 0.3.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/Area Class Diagram.dia +0 -0
- data/Area Class Diagram.png +0 -0
- data/Class Diagram.dia +0 -0
- data/Class Diagram.png +0 -0
- data/Example-Catalonia.md +361 -0
- data/Example-Flanders.md +486 -0
- data/Example-Greece.md +25 -0
- data/Example-Oslo.md +678 -0
- data/Example-UnitedKingdom-Referendum.md +132 -0
- data/Examples.md +15 -0
- data/LICENSE +674 -0
- data/README.md +103 -0
- data/Rakefile +18 -0
- data/Technical Documentation.md +14 -0
- data/bin/create_installation_package.sh +49 -0
- data/bin/install.sh +45 -0
- data/bin/sapor.rb +24 -0
- data/bin/sapor.sh +106 -0
- data/data/hu/hungary-2014.txt +1680 -0
- data/data/hu/hungary_2014_screen_scraper.rb +48 -0
- data/data/hu/hungary_2014_to_psv.rb +80 -0
- data/data/hu/index-2014.txt +106 -0
- data/data/pl/2015-gl-lis-okr.csv +42 -0
- data/data/pl/poland_2015_to_psv.rb +79 -0
- data/data/pl/poland_2015_to_psv_with_ko_and_rsw.rb +94 -0
- data/data/pl/poland_2015_to_psv_with_ko_konf_kp_l_and_zp.rb +100 -0
- data/data/pl/poland_2015_to_psv_with_ko_sld_and_wi.rb +92 -0
- data/data/pl/poland_2015_to_psv_with_sld.rb +84 -0
- data/data/pl/poland_2015_to_psv_with_sld_and_wi.rb +85 -0
- data/data/uk/inject_ukip_2015_as_brexit_2019_in_2017.rb +54 -0
- data/data/uk/united_kingdom_2015.txt +651 -0
- data/data/uk/united_kingdom_2015_to_psv.rb +104 -0
- data/data/uk/united_kingdom_2017.txt +651 -0
- data/data/uk/united_kingdom_2017_to_psv.rb +104 -0
- data/data/uk/united_kingdom_2017_to_psv_with_brexit_and_chuk.rb +113 -0
- data/data/uk/united_kingdom_2017_to_psv_with_tig.rb +111 -0
- data/lib/sapor.rb +150 -0
- data/lib/sapor/binomials_cache.rb +45 -0
- data/lib/sapor/combinations_distribution.rb +222 -0
- data/lib/sapor/denominators.rb +67 -0
- data/lib/sapor/dichotomies.rb +138 -0
- data/lib/sapor/dichotomy.rb +164 -0
- data/lib/sapor/first_past_the_post.rb +82 -0
- data/lib/sapor/largest_remainder.rb +118 -0
- data/lib/sapor/log4r_logger.rb +49 -0
- data/lib/sapor/log_facade.rb +40 -0
- data/lib/sapor/multi_district_leveled_proportional.rb +64 -0
- data/lib/sapor/multi_district_proportional.rb +123 -0
- data/lib/sapor/multi_district_variable_threshold_proportional.rb +128 -0
- data/lib/sapor/number_formatter.rb +45 -0
- data/lib/sapor/options.rb +73 -0
- data/lib/sapor/poll.rb +286 -0
- data/lib/sapor/polychotomy.rb +200 -0
- data/lib/sapor/pseudorandom_multirange_enumerator.rb +87 -0
- data/lib/sapor/referendum_polychotomy.rb +165 -0
- data/lib/sapor/regional_data/area.rb +82 -0
- data/lib/sapor/regional_data/austria.rb +84 -0
- data/lib/sapor/regional_data/belgium-brussels-2014.psv +46 -0
- data/lib/sapor/regional_data/belgium-brussels-20190526.psv +33 -0
- data/lib/sapor/regional_data/belgium-flanders-2014.psv +80 -0
- data/lib/sapor/regional_data/belgium-flanders-20190526.psv +74 -0
- data/lib/sapor/regional_data/belgium-wallonia-2014.psv +114 -0
- data/lib/sapor/regional_data/belgium-wallonia-20190526.psv +93 -0
- data/lib/sapor/regional_data/belgium.rb +97 -0
- data/lib/sapor/regional_data/belgium_brussels.rb +62 -0
- data/lib/sapor/regional_data/belgium_flanders.rb +64 -0
- data/lib/sapor/regional_data/belgium_wallonia.rb +63 -0
- data/lib/sapor/regional_data/catalonia-2012-2015.psv +100 -0
- data/lib/sapor/regional_data/catalonia-2012.psv +87 -0
- data/lib/sapor/regional_data/catalonia-2015-jxcat.psv +68 -0
- data/lib/sapor/regional_data/catalonia-2015-no-jxsi.psv +68 -0
- data/lib/sapor/regional_data/catalonia-2015.psv +63 -0
- data/lib/sapor/regional_data/catalonia-jxcat.rb +109 -0
- data/lib/sapor/regional_data/catalonia-no-jxsi.rb +96 -0
- data/lib/sapor/regional_data/catalonia.rb +96 -0
- data/lib/sapor/regional_data/denmark-20150618-with-e-and-p.psv +164 -0
- data/lib/sapor/regional_data/denmark-20150618-with-e.psv +153 -0
- data/lib/sapor/regional_data/denmark-20150618-with-p.psv +153 -0
- data/lib/sapor/regional_data/denmark-20150618.psv +142 -0
- data/lib/sapor/regional_data/denmark.rb +128 -0
- data/lib/sapor/regional_data/denmark_with_e.rb +128 -0
- data/lib/sapor/regional_data/denmark_with_e_and_p.rb +128 -0
- data/lib/sapor/regional_data/denmark_with_p.rb +128 -0
- data/lib/sapor/regional_data/estonia.rb +88 -0
- data/lib/sapor/regional_data/european-union-great-britain-20140522-brexit-chuk.psv +172 -0
- data/lib/sapor/regional_data/european-union-great-britain-20140522.psv +146 -0
- data/lib/sapor/regional_data/european-union-great-britain-20190523.psv +141 -0
- data/lib/sapor/regional_data/european-union-ireland-2014-ia-ri-sd.psv +64 -0
- data/lib/sapor/regional_data/european-union-ireland-2014-ia-sd.psv +60 -0
- data/lib/sapor/regional_data/european-union-ireland-2014-ia.psv +56 -0
- data/lib/sapor/regional_data/european-union-ireland-2014-sd.psv +56 -0
- data/lib/sapor/regional_data/european-union-ireland-2014.psv +50 -0
- data/lib/sapor/regional_data/european-union-ireland-20190524-ia.psv +58 -0
- data/lib/sapor/regional_data/european-union-ireland-20190524.psv +52 -0
- data/lib/sapor/regional_data/european_union_27_austria.rb +76 -0
- data/lib/sapor/regional_data/european_union_27_croatia.rb +81 -0
- data/lib/sapor/regional_data/european_union_27_denmark.rb +77 -0
- data/lib/sapor/regional_data/european_union_27_estonia.rb +74 -0
- data/lib/sapor/regional_data/european_union_27_finland.rb +74 -0
- data/lib/sapor/regional_data/european_union_27_ireland.rb +96 -0
- data/lib/sapor/regional_data/european_union_27_ireland_with_ia.rb +97 -0
- data/lib/sapor/regional_data/european_union_27_italy.rb +84 -0
- data/lib/sapor/regional_data/european_union_27_netherlands.rb +81 -0
- data/lib/sapor/regional_data/european_union_27_poland.rb +84 -0
- data/lib/sapor/regional_data/european_union_27_romania.rb +78 -0
- data/lib/sapor/regional_data/european_union_27_slovakia.rb +80 -0
- data/lib/sapor/regional_data/european_union_27_spain.rb +82 -0
- data/lib/sapor/regional_data/european_union_27_sweden.rb +76 -0
- data/lib/sapor/regional_data/european_union_austria.rb +76 -0
- data/lib/sapor/regional_data/european_union_bulgaria.rb +81 -0
- data/lib/sapor/regional_data/european_union_croatia.rb +81 -0
- data/lib/sapor/regional_data/european_union_cyprus.rb +72 -0
- data/lib/sapor/regional_data/european_union_czech_republic.rb +82 -0
- data/lib/sapor/regional_data/european_union_denmark.rb +77 -0
- data/lib/sapor/regional_data/european_union_estonia.rb +74 -0
- data/lib/sapor/regional_data/european_union_finland.rb +74 -0
- data/lib/sapor/regional_data/european_union_flanders.rb +74 -0
- data/lib/sapor/regional_data/european_union_france.rb +84 -0
- data/lib/sapor/regional_data/european_union_france_2019.rb +84 -0
- data/lib/sapor/regional_data/european_union_french_community_of_belgium.rb +73 -0
- data/lib/sapor/regional_data/european_union_germany.rb +86 -0
- data/lib/sapor/regional_data/european_union_great_britain.rb +98 -0
- data/lib/sapor/regional_data/european_union_greece.rb +77 -0
- data/lib/sapor/regional_data/european_union_hungary.rb +76 -0
- data/lib/sapor/regional_data/european_union_ireland.rb +96 -0
- data/lib/sapor/regional_data/european_union_ireland_with_ia.rb +97 -0
- data/lib/sapor/regional_data/european_union_italy.rb +84 -0
- data/lib/sapor/regional_data/european_union_latvia.rb +81 -0
- data/lib/sapor/regional_data/european_union_lithuania.rb +80 -0
- data/lib/sapor/regional_data/european_union_luxembourg.rb +75 -0
- data/lib/sapor/regional_data/european_union_malta.rb +71 -0
- data/lib/sapor/regional_data/european_union_netherlands.rb +81 -0
- data/lib/sapor/regional_data/european_union_northern_ireland.rb +75 -0
- data/lib/sapor/regional_data/european_union_poland.rb +84 -0
- data/lib/sapor/regional_data/european_union_portugal.rb +75 -0
- data/lib/sapor/regional_data/european_union_romania.rb +78 -0
- data/lib/sapor/regional_data/european_union_slovakia.rb +81 -0
- data/lib/sapor/regional_data/european_union_slovenia.rb +85 -0
- data/lib/sapor/regional_data/european_union_spain.rb +82 -0
- data/lib/sapor/regional_data/european_union_sweden.rb +76 -0
- data/lib/sapor/regional_data/finland-20150419-with-sin.psv +224 -0
- data/lib/sapor/regional_data/finland-20150419.psv +212 -0
- data/lib/sapor/regional_data/finland.rb +107 -0
- data/lib/sapor/regional_data/finland_with_sin.rb +107 -0
- data/lib/sapor/regional_data/flanders-2014.psv +96 -0
- data/lib/sapor/regional_data/flanders-20190526.psv +87 -0
- data/lib/sapor/regional_data/flanders.rb +115 -0
- data/lib/sapor/regional_data/france.rb +38 -0
- data/lib/sapor/regional_data/greece.rb +92 -0
- data/lib/sapor/regional_data/hungary-2014.psv +2104 -0
- data/lib/sapor/regional_data/hungary.rb +116 -0
- data/lib/sapor/regional_data/iceland-20161029-midflokkurinn.psv +94 -0
- data/lib/sapor/regional_data/iceland-20161029.psv +88 -0
- data/lib/sapor/regional_data/iceland-20171028.psv +85 -0
- data/lib/sapor/regional_data/iceland.rb +133 -0
- data/lib/sapor/regional_data/latvia-20141004-kpv-p-par.psv +109 -0
- data/lib/sapor/regional_data/latvia-20141004-kpv-par.psv +103 -0
- data/lib/sapor/regional_data/latvia-20141004-kpv.psv +97 -0
- data/lib/sapor/regional_data/latvia-20141004.psv +89 -0
- data/lib/sapor/regional_data/latvia.rb +112 -0
- data/lib/sapor/regional_data/latvia_kpv.rb +112 -0
- data/lib/sapor/regional_data/latvia_kpv_p_par.rb +112 -0
- data/lib/sapor/regional_data/latvia_kpv_par.rb +112 -0
- data/lib/sapor/regional_data/luxembourg-20131020.psv +76 -0
- data/lib/sapor/regional_data/luxembourg.rb +82 -0
- data/lib/sapor/regional_data/netherlands.rb +108 -0
- data/lib/sapor/regional_data/norway.rb +425 -0
- data/lib/sapor/regional_data/norwegian_municipality.rb +68 -0
- data/lib/sapor/regional_data/poland-20151025-with-ko-and-l-without-n-po-r-and-zl.psv +321 -0
- data/lib/sapor/regional_data/poland-20151025-with-ko-konf-kp-l-and-zp-without-k-k15-n-pis-po-psl-r-and-zl.psv +280 -0
- data/lib/sapor/regional_data/poland-20151025-with-ko-sld-and-wi-without-n-po-and-zl.psv +403 -0
- data/lib/sapor/regional_data/poland-20151025-with-sld-and-wi-without-zl.psv +444 -0
- data/lib/sapor/regional_data/poland-20151025-with-sld-without-zl.psv +403 -0
- data/lib/sapor/regional_data/poland-20151025.psv +403 -0
- data/lib/sapor/regional_data/poland.rb +125 -0
- data/lib/sapor/regional_data/poland_with_ko_and_l_without_n_po_r_and_zl.rb +122 -0
- data/lib/sapor/regional_data/poland_with_ko_konf_kp_l_and_zp_without_k_k15_n_pis_po_psl_r_and_zl.rb +123 -0
- data/lib/sapor/regional_data/poland_with_ko_sld_and_wi_without_n_po_and_zl.rb +125 -0
- data/lib/sapor/regional_data/poland_with_sld_and_wi_without_zl.rb +126 -0
- data/lib/sapor/regional_data/poland_with_sld_without_zl.rb +126 -0
- data/lib/sapor/regional_data/portugal-20151004-with-a-and-ch-without-paf.psv +438 -0
- data/lib/sapor/regional_data/portugal-20151004-with-a-and-il-without-paf.psv +438 -0
- data/lib/sapor/regional_data/portugal-20151004-with-a-ch-and-il-without-paf.psv +461 -0
- data/lib/sapor/regional_data/portugal-20151004-with-a-without-paf.psv +415 -0
- data/lib/sapor/regional_data/portugal-20151004-with-ch-and-il-without-paf.psv +438 -0
- data/lib/sapor/regional_data/portugal-20151004-without-paf.psv +392 -0
- data/lib/sapor/regional_data/portugal-20151004.psv +370 -0
- data/lib/sapor/regional_data/portugal.rb +101 -0
- data/lib/sapor/regional_data/portugal_with_a_and_ch_without_paf.rb +92 -0
- data/lib/sapor/regional_data/portugal_with_a_and_il_without_paf.rb +92 -0
- data/lib/sapor/regional_data/portugal_with_a_ch_and_il_without_paf.rb +92 -0
- data/lib/sapor/regional_data/portugal_with_a_without_paf.rb +92 -0
- data/lib/sapor/regional_data/portugal_with_ch_and_il_without_paf.rb +92 -0
- data/lib/sapor/regional_data/portugal_without_paf.rb +92 -0
- data/lib/sapor/regional_data/slovakia.rb +81 -0
- data/lib/sapor/regional_data/slovenia.rb +114 -0
- data/lib/sapor/regional_data/spain-20160626.psv +619 -0
- data/lib/sapor/regional_data/spain.rb +136 -0
- data/lib/sapor/regional_data/sweden.rb +92 -0
- data/lib/sapor/regional_data/sweden_20140914.rb +89 -0
- data/lib/sapor/regional_data/united_kingdom-2015.psv +4358 -0
- data/lib/sapor/regional_data/united_kingdom-20170608-brexit-chuk.psv +5154 -0
- data/lib/sapor/regional_data/united_kingdom-20170608-brexit.psv +4521 -0
- data/lib/sapor/regional_data/united_kingdom-20170608-tig.psv +4529 -0
- data/lib/sapor/regional_data/united_kingdom-20170608.psv +3894 -0
- data/lib/sapor/regional_data/united_kingdom.rb +94 -0
- data/lib/sapor/regional_data/united_kingdom_with_brexit.rb +110 -0
- data/lib/sapor/regional_data/united_kingdom_with_brexit_and_chuk.rb +111 -0
- data/lib/sapor/regional_data/united_kingdom_with_tig.rb +111 -0
- data/lib/sapor/regional_data/utopia.rb +66 -0
- data/lib/sapor/regional_data/wallonia-2014.psv +101 -0
- data/lib/sapor/regional_data/wallonia-20190526.psv +88 -0
- data/lib/sapor/regional_data/wallonia.rb +112 -0
- data/lib/sapor/representatives_polychotomy.rb +338 -0
- data/lib/sapor/single_district_proportional.rb +75 -0
- data/sapor.gemspec +35 -0
- data/spec/integration/area_spec.rb +28 -0
- data/spec/integration/poll_spec.rb +112 -0
- data/spec/integration/sample.poll +8 -0
- data/spec/spec_helper.rb +31 -0
- data/spec/unit/area_spec.rb +115 -0
- data/spec/unit/austria_spec.rb +76 -0
- data/spec/unit/belgium_brussels_spec.rb +58 -0
- data/spec/unit/belgium_flanders_spec.rb +62 -0
- data/spec/unit/belgium_spec.rb +26 -0
- data/spec/unit/belgium_wallonia_spec.rb +65 -0
- data/spec/unit/binomials_cache_spec.rb +34 -0
- data/spec/unit/catalonia_spec.rb +74 -0
- data/spec/unit/combinations_distribution_spec.rb +241 -0
- data/spec/unit/denmark_spec.rb +56 -0
- data/spec/unit/denmark_with_e_and_p_spec.rb +58 -0
- data/spec/unit/denmark_with_e_spec.rb +57 -0
- data/spec/unit/denmark_with_p_spec.rb +57 -0
- data/spec/unit/denominators_spec.rb +40 -0
- data/spec/unit/dichotomies_spec.rb +154 -0
- data/spec/unit/dichotomy_spec.rb +320 -0
- data/spec/unit/estonia_spec.rb +65 -0
- data/spec/unit/european_union_27_austria_spec.rb +61 -0
- data/spec/unit/european_union_27_croatia_spec.rb +60 -0
- data/spec/unit/european_union_27_denmark_spec.rb +62 -0
- data/spec/unit/european_union_27_estonia_spec.rb +94 -0
- data/spec/unit/european_union_27_finland_spec.rb +75 -0
- data/spec/unit/european_union_27_ireland_spec.rb +72 -0
- data/spec/unit/european_union_27_ireland_with_ia_spec.rb +74 -0
- data/spec/unit/european_union_27_italy_spec.rb +69 -0
- data/spec/unit/european_union_27_netherlands_spec.rb +81 -0
- data/spec/unit/european_union_27_poland_spec.rb +69 -0
- data/spec/unit/european_union_27_romania_spec.rb +67 -0
- data/spec/unit/european_union_27_slovakia_spec.rb +111 -0
- data/spec/unit/european_union_27_spain_spec.rb +130 -0
- data/spec/unit/european_union_27_sweden_spec.rb +89 -0
- data/spec/unit/european_union_austria_spec.rb +61 -0
- data/spec/unit/european_union_bulgaria_spec.rb +97 -0
- data/spec/unit/european_union_croatia_spec.rb +59 -0
- data/spec/unit/european_union_cyprus_spec.rb +65 -0
- data/spec/unit/european_union_czech_republic_spec.rb +125 -0
- data/spec/unit/european_union_denmark_spec.rb +61 -0
- data/spec/unit/european_union_estonia_spec.rb +93 -0
- data/spec/unit/european_union_finland_spec.rb +75 -0
- data/spec/unit/european_union_flanders_spec.rb +56 -0
- data/spec/unit/european_union_france_2019_spec.rb +73 -0
- data/spec/unit/european_union_france_spec.rb +73 -0
- data/spec/unit/european_union_french_community_of_belgium_spec.rb +61 -0
- data/spec/unit/european_union_germany_spec.rb +90 -0
- data/spec/unit/european_union_great_britain_spec.rb +87 -0
- data/spec/unit/european_union_greece_spec.rb +148 -0
- data/spec/unit/european_union_hungary_spec.rb +57 -0
- data/spec/unit/european_union_ireland_spec.rb +72 -0
- data/spec/unit/european_union_ireland_with_ia_spec.rb +74 -0
- data/spec/unit/european_union_italy_spec.rb +69 -0
- data/spec/unit/european_union_latvia_spec.rb +76 -0
- data/spec/unit/european_union_lithuania_spec.rb +68 -0
- data/spec/unit/european_union_luxembourg_spec.rb +63 -0
- data/spec/unit/european_union_malta_spec.rb +60 -0
- data/spec/unit/european_union_netherlands_spec.rb +81 -0
- data/spec/unit/european_union_northern_ireland_spec.rb +66 -0
- data/spec/unit/european_union_poland_spec.rb +69 -0
- data/spec/unit/european_union_portugal_spec.rb +77 -0
- data/spec/unit/european_union_romania_spec.rb +67 -0
- data/spec/unit/european_union_slovakia_spec.rb +111 -0
- data/spec/unit/european_union_slovenia_spec.rb +77 -0
- data/spec/unit/european_union_spain_spec.rb +129 -0
- data/spec/unit/european_union_sweden_spec.rb +89 -0
- data/spec/unit/finland_spec.rb +65 -0
- data/spec/unit/finland_with_sin_spec.rb +67 -0
- data/spec/unit/first_past_the_post_spec.rb +54 -0
- data/spec/unit/flanders_spec.rb +70 -0
- data/spec/unit/france_spec.rb +32 -0
- data/spec/unit/greece_spec.rb +118 -0
- data/spec/unit/hungary_spec.rb +132 -0
- data/spec/unit/iceland_spec.rb +57 -0
- data/spec/unit/largest_remainder_spec.rb +79 -0
- data/spec/unit/latvia_kpv_p_par_spec.rb +38 -0
- data/spec/unit/latvia_kpv_par_spec.rb +38 -0
- data/spec/unit/latvia_kpv_spec.rb +38 -0
- data/spec/unit/latvia_spec.rb +60 -0
- data/spec/unit/luxembourg_spec.rb +54 -0
- data/spec/unit/multi_district_leveled_proportional_spec.rb +49 -0
- data/spec/unit/multi_district_proportional_spec.rb +81 -0
- data/spec/unit/netherlands_spec.rb +107 -0
- data/spec/unit/norway_spec.rb +64 -0
- data/spec/unit/norwegian_municipality_spec.rb +89 -0
- data/spec/unit/number_formatter_spec.rb +173 -0
- data/spec/unit/poland_spec.rb +62 -0
- data/spec/unit/poland_with_ko_and_l_without_n_po_r_and_zl_spec.rb +60 -0
- data/spec/unit/poland_with_ko_konf_kp_l_and_zp_without_k_k15_n_pis_po_psl_r_and_zl_spec.rb +59 -0
- data/spec/unit/poland_with_ko_sld_and_wi_without_n_po_and_zl_spec.rb +62 -0
- data/spec/unit/poland_with_sld_and_wi_without_zl_spec.rb +63 -0
- data/spec/unit/poland_with_sld_without_zl_spec.rb +62 -0
- data/spec/unit/poll_spec.rb +110 -0
- data/spec/unit/portugal_spec.rb +66 -0
- data/spec/unit/portugal_with_a_and_ch_without_paf_spec.rb +68 -0
- data/spec/unit/portugal_with_a_and_il_without_paf_spec.rb +68 -0
- data/spec/unit/portugal_with_a_ch_and_il_without_paf_spec.rb +69 -0
- data/spec/unit/portugal_with_a_without_paf_spec.rb +67 -0
- data/spec/unit/portugal_with_ch_and_il_without_paf_spec.rb +68 -0
- data/spec/unit/portugal_without_paf_spec.rb +66 -0
- data/spec/unit/pseudorandom_multirange_enumerator_spec.rb +82 -0
- data/spec/unit/referendum_polychotomy_spec.rb +289 -0
- data/spec/unit/representatives_polychotomy_spec.rb +332 -0
- data/spec/unit/slovakia_spec.rb +99 -0
- data/spec/unit/slovenia_spec.rb +80 -0
- data/spec/unit/spain_spec.rb +101 -0
- data/spec/unit/sweden_20140914_spec.rb +112 -0
- data/spec/unit/sweden_spec.rb +113 -0
- data/spec/unit/united_kingdom_spec.rb +65 -0
- data/spec/unit/united_kingdom_with_brexit_and_chuk_spec.rb +67 -0
- data/spec/unit/united_kingdom_with_brexit_spec.rb +66 -0
- data/spec/unit/united_kingdom_with_tig_spec.rb +66 -0
- data/spec/unit/wallonia_spec.rb +70 -0
- metadata +490 -0
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
#
|
|
3
|
+
# Statistical Analysis of Polling Results (SAPoR)
|
|
4
|
+
# Copyright (C) 2016 Filip van Laenen <f.a.vanlaenen@ieee.org>
|
|
5
|
+
#
|
|
6
|
+
# This file is part of SAPoR.
|
|
7
|
+
#
|
|
8
|
+
# SAPoR is free software: you can redistribute it and/or modify it under the
|
|
9
|
+
# terms of the GNU General Public License as published by the Free Software
|
|
10
|
+
# Foundation, either version 3 of the License, or (at your option) any later
|
|
11
|
+
# version.
|
|
12
|
+
#
|
|
13
|
+
# SAPoR is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
14
|
+
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
15
|
+
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
16
|
+
#
|
|
17
|
+
# You can find a copy of the GNU General Public License in /doc/gpl.txt
|
|
18
|
+
#
|
|
19
|
+
|
|
20
|
+
require 'spec_helper'
|
|
21
|
+
|
|
22
|
+
describe Sapor::EuropeanUnion27Spain, '#area_code' do
|
|
23
|
+
it 'returns EU27[ES] as the area code' do
|
|
24
|
+
expect(Sapor::EuropeanUnion27Spain.instance.area_code).to \
|
|
25
|
+
eq('EU27[ES]')
|
|
26
|
+
end
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
describe Sapor::EuropeanUnion27Spain, '#no_of_seats' do
|
|
30
|
+
it 'returns 59 as the number of seats' do
|
|
31
|
+
expect(Sapor::EuropeanUnion27Spain.instance.no_of_seats).to eq(59)
|
|
32
|
+
end
|
|
33
|
+
end
|
|
34
|
+
|
|
35
|
+
describe Sapor::EuropeanUnion27Spain, '#population_size' do
|
|
36
|
+
it 'returns a population size of 22,410,049' do
|
|
37
|
+
expect(Sapor::EuropeanUnion27Spain.instance.population_size).to \
|
|
38
|
+
eq(22_410_049)
|
|
39
|
+
end
|
|
40
|
+
end
|
|
41
|
+
|
|
42
|
+
describe Sapor::EuropeanUnion27Spain, '#seats' do
|
|
43
|
+
it 'calculates the number of seats using the votes of the 2014 election' do
|
|
44
|
+
results = { 'Partido Popular (EPP)' => 4_098_339,
|
|
45
|
+
'Partido Socialista Obrero Español (S&D)' => 3_614_232,
|
|
46
|
+
'La Izquierda Plural (GUE/NGL)' => 1_575_308,
|
|
47
|
+
'Podemos (GUE/NGL)' => 1_253_837,
|
|
48
|
+
'Unión Progreso y Democracia (ALDE)' => 1_022_232,
|
|
49
|
+
'Coalición por Europa (ALDE)' => 851_971,
|
|
50
|
+
'L’Esquerra pel Dret a Decidir (Greens/EFA)' => 630_072,
|
|
51
|
+
'Ciudadanos–Partido de la Ciudadanía (ALDE)' => 497_146,
|
|
52
|
+
'Los Pueblos Deciden (GUE/NGL)' => 326_464,
|
|
53
|
+
'Primavera Europea (Greens/EFA)' => 302_266,
|
|
54
|
+
'Vox (ECR)' => 246_833,
|
|
55
|
+
'Partido Animalista Contra el Maltrato Animal (—)' => 177_499,
|
|
56
|
+
'Escaños en Blanco (—)' => 115_682,
|
|
57
|
+
'Movimiento de Renovación Democrática de la Ciudadanía (—)' => \
|
|
58
|
+
105_666,
|
|
59
|
+
'Partido X (—)' => 100_561,
|
|
60
|
+
'Partido Andalucista (Greens/EFA)' => 49_523,
|
|
61
|
+
'Confederación Pirata (—)' => 38_690,
|
|
62
|
+
'Foro de Ciudadanos (—)' => 32_962,
|
|
63
|
+
'Agrupación de Electores de Discapacitados y Enfermedades' \
|
|
64
|
+
' Raras (—)' => 32_833,
|
|
65
|
+
'Recortes Cero (—)' => 30_827,
|
|
66
|
+
'Partido Comunista de los Pueblos de España (—)' => 29_324,
|
|
67
|
+
'Iniciativa Feminista (—)' => 23_140,
|
|
68
|
+
'Falange Española de las JONS (—)' => 21_687,
|
|
69
|
+
'Ciudadanos Libres Unidos (—)' => 18_287,
|
|
70
|
+
'Impulso Social (—)' => 17_879,
|
|
71
|
+
'La España en Marcha (—)' => 17_035,
|
|
72
|
+
'Partido Humanista (—)' => 14_896,
|
|
73
|
+
'Democracia Nacional (—)' => 13_079,
|
|
74
|
+
'Proyecto Europa (—)' => 11_502,
|
|
75
|
+
'Partido da Terra (—)' => 9_940,
|
|
76
|
+
'Partido de la Libertad Individual (—)' => 9_670,
|
|
77
|
+
'Movimiento Social Republicano (—)' => 8_909,
|
|
78
|
+
'Extremadura Unida (—)' => 8_821,
|
|
79
|
+
'Alternativa Republicana (—)' => 8_593,
|
|
80
|
+
'Por la República, Por la Ruptura con la Unión Europea (—)' => \
|
|
81
|
+
8_309,
|
|
82
|
+
'Solidaridad y Autogestión Internacionalista (—)' => 6_929,
|
|
83
|
+
'Salamanca-Zamora-León (—)' => 6_759,
|
|
84
|
+
'Extremeños por Europa Coalición electoral (—)' => 5_967,
|
|
85
|
+
'Movimiento Corriente Roja (—)' => 4_980 }
|
|
86
|
+
seats = Sapor::EuropeanUnion27Spain.instance.seats(results)
|
|
87
|
+
expect(seats['Partido Popular (EPP)']).to eq(16 + 2)
|
|
88
|
+
expect(seats['Partido Socialista Obrero Español (S&D)']).to eq(14 + 2)
|
|
89
|
+
expect(seats['La Izquierda Plural (GUE/NGL)']).to eq(6)
|
|
90
|
+
expect(seats['Podemos (GUE/NGL)']).to eq(5)
|
|
91
|
+
expect(seats['Unión Progreso y Democracia (ALDE)']).to eq(4)
|
|
92
|
+
expect(seats['Coalición por Europa (ALDE)']).to eq(3)
|
|
93
|
+
expect(seats['L’Esquerra pel Dret a Decidir (Greens/EFA)']).to eq(2)
|
|
94
|
+
expect(seats['Ciudadanos–Partido de la Ciudadanía (ALDE)']).to eq(2)
|
|
95
|
+
expect(seats['Los Pueblos Deciden (GUE/NGL)']).to eq(1)
|
|
96
|
+
expect(seats['Primavera Europea (Greens/EFA)']).to eq(1)
|
|
97
|
+
expect(seats['Vox (ECR)']).to eq(0 + 1)
|
|
98
|
+
expect(seats['Partido Animalista Contra el Maltrato Animal (—)']).to eq(0)
|
|
99
|
+
expect(seats['Escaños en Blanco (—)']).to eq(0)
|
|
100
|
+
expect(seats['Movimiento de Renovación Democrática de la Ciudadanía (—)']) \
|
|
101
|
+
.to eq(0)
|
|
102
|
+
expect(seats['Partido X (—)']).to eq(0)
|
|
103
|
+
expect(seats['Partido Andalucista (Greens/EFA)']).to eq(0)
|
|
104
|
+
expect(seats['Confederación Pirata (—)']).to eq(0)
|
|
105
|
+
expect(seats['Foro de Ciudadanos (—)']).to eq(0)
|
|
106
|
+
expect(seats['Agrupación de Electores de Discapacitados y Enfermedades' \
|
|
107
|
+
' Raras (—)']).to eq(0)
|
|
108
|
+
expect(seats['Recortes Cero (—)']).to eq(0)
|
|
109
|
+
expect(seats['Partido Comunista de los Pueblos de España (—)']).to eq(0)
|
|
110
|
+
expect(seats['Iniciativa Feminista (—)']).to eq(0)
|
|
111
|
+
expect(seats['Falange Española de las JONS (—)']).to eq(0)
|
|
112
|
+
expect(seats['Ciudadanos Libres Unidos (—)']).to eq(0)
|
|
113
|
+
expect(seats['Impulso Social (—)']).to eq(0)
|
|
114
|
+
expect(seats['La España en Marcha (—)']).to eq(0)
|
|
115
|
+
expect(seats['Partido Humanista (—)']).to eq(0)
|
|
116
|
+
expect(seats['Democracia Nacional (—)']).to eq(0)
|
|
117
|
+
expect(seats['Proyecto Europa (—)']).to eq(0)
|
|
118
|
+
expect(seats['Partido da Terra (—)']).to eq(0)
|
|
119
|
+
expect(seats['Partido de la Libertad Individual (—)']).to eq(0)
|
|
120
|
+
expect(seats['Movimiento Social Republicano (—)']).to eq(0)
|
|
121
|
+
expect(seats['Extremadura Unida (—)']).to eq(0)
|
|
122
|
+
expect(seats['Alternativa Republicana (—)']).to eq(0)
|
|
123
|
+
expect(seats['Por la República, Por la Ruptura con la Unión Europea (—)']) \
|
|
124
|
+
.to eq(0)
|
|
125
|
+
expect(seats['Solidaridad y Autogestión Internacionalista (—)']).to eq(0)
|
|
126
|
+
expect(seats['Salamanca-Zamora-León (—)']).to eq(0)
|
|
127
|
+
expect(seats['Extremeños por Europa Coalición electoral (—)']).to eq(0)
|
|
128
|
+
expect(seats['Movimiento Corriente Roja (—)']).to eq(0)
|
|
129
|
+
end
|
|
130
|
+
end
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
#
|
|
3
|
+
# Statistical Analysis of Polling Results (SAPoR)
|
|
4
|
+
# Copyright (C) 2016 Filip van Laenen <f.a.vanlaenen@ieee.org>
|
|
5
|
+
#
|
|
6
|
+
# This file is part of SAPoR.
|
|
7
|
+
#
|
|
8
|
+
# SAPoR is free software: you can redistribute it and/or modify it under the
|
|
9
|
+
# terms of the GNU General Public License as published by the Free Software
|
|
10
|
+
# Foundation, either version 3 of the License, or (at your option) any later
|
|
11
|
+
# version.
|
|
12
|
+
#
|
|
13
|
+
# SAPoR is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
14
|
+
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
15
|
+
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
16
|
+
#
|
|
17
|
+
# You can find a copy of the GNU General Public License in /doc/gpl.txt
|
|
18
|
+
#
|
|
19
|
+
|
|
20
|
+
require 'spec_helper'
|
|
21
|
+
|
|
22
|
+
describe Sapor::EuropeanUnion27Sweden, '#area_code' do
|
|
23
|
+
it 'returns EU27[SE] as the area code' do
|
|
24
|
+
expect(Sapor::EuropeanUnion27Sweden.instance.area_code).to eq('EU27[SE]')
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
describe Sapor::EuropeanUnion27Sweden, '#no_of_seats' do
|
|
29
|
+
it 'returns 21 as the number of seats' do
|
|
30
|
+
expect(Sapor::EuropeanUnion27Sweden.instance.no_of_seats).to eq(21)
|
|
31
|
+
end
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
describe Sapor::EuropeanUnion27Sweden, '#population_size' do
|
|
35
|
+
it 'returns a population size of 4,151,470' do
|
|
36
|
+
expect(Sapor::EuropeanUnion27Sweden.instance.population_size).to \
|
|
37
|
+
eq(4_151_470)
|
|
38
|
+
end
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
describe Sapor::EuropeanUnion27Sweden, '#seats' do
|
|
42
|
+
it 'calculates the number of seats for the election of 2014' do
|
|
43
|
+
results = { 'Sveriges socialdemokratiska arbetareparti (S&D)' => 899_074,
|
|
44
|
+
'Miljöpartiet de gröna (Greens/EFA)' => 572_591,
|
|
45
|
+
'Moderata samlingspartiet (EPP)' => 507_488,
|
|
46
|
+
'Liberalerna (ALDE)' => 368_514,
|
|
47
|
+
'Sverigedemokraterna (EFDD)' => 359_248,
|
|
48
|
+
'Centerpartiet (ALDE)' => 241_101,
|
|
49
|
+
'Vänsterpartiet (GUE/NGL)' => 234_272,
|
|
50
|
+
'Kristdemokraterna (EPP)' => 220_574,
|
|
51
|
+
'Feministiskt initiativ (S&D)' => 204_005,
|
|
52
|
+
'Piratpartiet (Greens/EFA)' => 82_763,
|
|
53
|
+
'Junilistan (GUE/NGL)' => 11_629,
|
|
54
|
+
'Djurens parti (GUE/NGL)' => 8_773,
|
|
55
|
+
'Liberala partiet (—)' => 492,
|
|
56
|
+
'Europeiska arbetarpartiet (—)' => 170,
|
|
57
|
+
'Sverigesmultidemokrater (—)' => 133,
|
|
58
|
+
'Sverige ut ur EU–Frihetliga Rättvisepartiet (—)' => 106,
|
|
59
|
+
'Socialistiska välfärdspartiet (—)' => 86,
|
|
60
|
+
'Äkta demokrati (—)' => 72,
|
|
61
|
+
'Sveriges nationella demokratiska parti (—)' => 49,
|
|
62
|
+
'666 för en EU:s super-state med frihet, jämlikhet, rättvisa,' \
|
|
63
|
+
' fred, kärlek och lyckan (—)' => 11,
|
|
64
|
+
'Republicans right (—)' => 9 }
|
|
65
|
+
seats = Sapor::EuropeanUnion27Sweden.instance.seats(results)
|
|
66
|
+
expect(seats['Sveriges socialdemokratiska arbetareparti (S&D)']).to eq(5 + 1)
|
|
67
|
+
expect(seats['Miljöpartiet de gröna (Greens/EFA)']).to eq(4)
|
|
68
|
+
expect(seats['Moderata samlingspartiet (EPP)']).to eq(3)
|
|
69
|
+
expect(seats['Liberalerna (ALDE)']).to eq(2)
|
|
70
|
+
expect(seats['Sverigedemokraterna (EFDD)']).to eq(2)
|
|
71
|
+
expect(seats['Centerpartiet (ALDE)']).to eq(1)
|
|
72
|
+
expect(seats['Vänsterpartiet (GUE/NGL)']).to eq(1)
|
|
73
|
+
expect(seats['Kristdemokraterna (EPP)']).to eq(1)
|
|
74
|
+
expect(seats['Feministiskt initiativ (S&D)']).to eq(1)
|
|
75
|
+
expect(seats['Piratpartiet (Greens/EFA)']).to eq(0)
|
|
76
|
+
expect(seats['Junilistan (GUE/NGL)']).to eq(0)
|
|
77
|
+
expect(seats['Djurens parti (GUE/NGL)']).to eq(0)
|
|
78
|
+
expect(seats['Liberala partiet (—)']).to eq(0)
|
|
79
|
+
expect(seats['Europeiska arbetarpartiet (—)']).to eq(0)
|
|
80
|
+
expect(seats['Sverigesmultidemokrater (—)']).to eq(0)
|
|
81
|
+
expect(seats['Sverige ut ur EU–Frihetliga Rättvisepartiet (—)']).to eq(0)
|
|
82
|
+
expect(seats['Socialistiska välfärdspartiet (—)']).to eq(0)
|
|
83
|
+
expect(seats['Äkta demokrati (—)']).to eq(0)
|
|
84
|
+
expect(seats['Sveriges nationella demokratiska parti (—)']).to eq(0)
|
|
85
|
+
expect(seats['666 för en EU:s super-state med frihet, jämlikhet,' \
|
|
86
|
+
' rättvisa, fred, kärlek och lyckan (—)']).to eq(0)
|
|
87
|
+
expect(seats['Republicans right (—)']).to eq(0)
|
|
88
|
+
end
|
|
89
|
+
end
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
#
|
|
3
|
+
# Statistical Analysis of Polling Results (SAPoR)
|
|
4
|
+
# Copyright (C) 2016 Filip van Laenen <f.a.vanlaenen@ieee.org>
|
|
5
|
+
#
|
|
6
|
+
# This file is part of SAPoR.
|
|
7
|
+
#
|
|
8
|
+
# SAPoR is free software: you can redistribute it and/or modify it under the
|
|
9
|
+
# terms of the GNU General Public License as published by the Free Software
|
|
10
|
+
# Foundation, either version 3 of the License, or (at your option) any later
|
|
11
|
+
# version.
|
|
12
|
+
#
|
|
13
|
+
# SAPoR is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
14
|
+
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
15
|
+
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
16
|
+
#
|
|
17
|
+
# You can find a copy of the GNU General Public License in /doc/gpl.txt
|
|
18
|
+
#
|
|
19
|
+
|
|
20
|
+
require 'spec_helper'
|
|
21
|
+
|
|
22
|
+
describe Sapor::EuropeanUnionAustria, '#area_code' do
|
|
23
|
+
it 'returns EU[AT] as the area code' do
|
|
24
|
+
expect(Sapor::EuropeanUnionAustria.instance.area_code).to eq('EU[AT]')
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
describe Sapor::EuropeanUnionAustria, '#no_of_seats' do
|
|
29
|
+
it 'returns 18 as the number of seats' do
|
|
30
|
+
expect(Sapor::EuropeanUnionAustria.instance.no_of_seats).to eq(18)
|
|
31
|
+
end
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
describe Sapor::EuropeanUnionAustria, '#population_size' do
|
|
35
|
+
it 'returns a population size of 3,834,656' do
|
|
36
|
+
expect(Sapor::EuropeanUnionAustria.instance.population_size).to \
|
|
37
|
+
eq(3_834_656)
|
|
38
|
+
end
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
describe Sapor::EuropeanUnionAustria, '#seats' do
|
|
42
|
+
it 'calculates the number of seats for the election of 2019' do
|
|
43
|
+
results = { 'Österreichische Volkspartei (EPP)' => 1_305_956,
|
|
44
|
+
'Sozialdemokratische Partei Österreichs (S&D)' => 903_151,
|
|
45
|
+
'Freiheitliche Partei Österreichs (ENF)' => 650_114,
|
|
46
|
+
'Die Grünen–Die Grüne Alternative (Greens/EFA)' => 532_193,
|
|
47
|
+
'NEOS–Das Neue Österreich und Liberales Forum (ALDE)' => \
|
|
48
|
+
319_024,
|
|
49
|
+
'EUROPA JETZT (*)' => 39_087,
|
|
50
|
+
'Kommunistische Partei Österreichs (*)' => 30_087 }
|
|
51
|
+
seats = Sapor::EuropeanUnionAustria.instance.seats(results)
|
|
52
|
+
expect(seats['Österreichische Volkspartei (EPP)']).to eq(7)
|
|
53
|
+
expect(seats['Sozialdemokratische Partei Österreichs (S&D)']).to eq(5)
|
|
54
|
+
expect(seats['Freiheitliche Partei Österreichs (ENF)']).to eq(3)
|
|
55
|
+
expect(seats['Die Grünen–Die Grüne Alternative (Greens/EFA)']).to eq(2)
|
|
56
|
+
expect(seats['NEOS–Das Neue Österreich und Liberales Forum (ALDE)']).to \
|
|
57
|
+
eq(1)
|
|
58
|
+
expect(seats['EUROPA JETZT (*)']).to eq(0)
|
|
59
|
+
expect(seats['Kommunistische Partei Österreichs (*)']).to eq(0)
|
|
60
|
+
end
|
|
61
|
+
end
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
#
|
|
3
|
+
# Statistical Analysis of Polling Results (SAPoR)
|
|
4
|
+
# Copyright (C) 2016 Filip van Laenen <f.a.vanlaenen@ieee.org>
|
|
5
|
+
#
|
|
6
|
+
# This file is part of SAPoR.
|
|
7
|
+
#
|
|
8
|
+
# SAPoR is free software: you can redistribute it and/or modify it under the
|
|
9
|
+
# terms of the GNU General Public License as published by the Free Software
|
|
10
|
+
# Foundation, either version 3 of the License, or (at your option) any later
|
|
11
|
+
# version.
|
|
12
|
+
#
|
|
13
|
+
# SAPoR is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
14
|
+
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
15
|
+
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
16
|
+
#
|
|
17
|
+
# You can find a copy of the GNU General Public License in /doc/gpl.txt
|
|
18
|
+
#
|
|
19
|
+
|
|
20
|
+
require 'spec_helper'
|
|
21
|
+
|
|
22
|
+
describe Sapor::EuropeanUnionBulgaria, '#area_code' do
|
|
23
|
+
it 'returns EU[BG] as the area code' do
|
|
24
|
+
expect(Sapor::EuropeanUnionBulgaria.instance.area_code).to eq('EU[BG]')
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
describe Sapor::EuropeanUnionBulgaria, '#no_of_seats' do
|
|
29
|
+
it 'returns 17 as the number of seats' do
|
|
30
|
+
expect(Sapor::EuropeanUnionBulgaria.instance.no_of_seats).to eq(17)
|
|
31
|
+
end
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
describe Sapor::EuropeanUnionBulgaria, '#population_size' do
|
|
35
|
+
it 'returns a population size of 2,015,320' do
|
|
36
|
+
expect(Sapor::EuropeanUnionBulgaria.instance.population_size).to \
|
|
37
|
+
eq(2_015_320)
|
|
38
|
+
end
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
describe Sapor::EuropeanUnionBulgaria, '#seats' do
|
|
42
|
+
it 'calculates the number of seats for the election of 2014' do
|
|
43
|
+
results = { 'Граждани за европейско развитие на България (EPP)' => 680_838,
|
|
44
|
+
'КОАЛИЦИЯ ЗА БЪЛГАРИЯ (S&D)' => 424_037,
|
|
45
|
+
'Движение за права и свободи (ALDE)' => 386_725,
|
|
46
|
+
'БЪЛГАРИЯ БЕЗ ЦЕНЗУРА, ВМРО, ЗНС, ГЕРГЬОВДЕН (ECR)' => 238_629,
|
|
47
|
+
'РЕФОРМАТОРСКИ БЛОК (EPP)' => 144_532,
|
|
48
|
+
'АЛТЕРНАТИВА ЗА БЪЛГАРСКО ВЪЗРАЖДАНЕ (—)' => 90_061,
|
|
49
|
+
'НАЦИОНАЛЕН ФРОНТ ЗА СПАСЕНИЕ НА БЪЛГАРИЯ (EFDD)' => 68_376,
|
|
50
|
+
'АТАКА (—)' => 66_210,
|
|
51
|
+
'ГЛАС НАРОДЕН (—)' => 22_440,
|
|
52
|
+
'Коалиция КОД–Антония Първанова, Илиана Раева–ОБ, НДСВ, СДП' \
|
|
53
|
+
' (—)' => 20_487,
|
|
54
|
+
'ЗЕЛЕНИТЕ (—)' => 12_547,
|
|
55
|
+
'БЪЛГАРСКАТА ЛЕВИЦА (—)' => 11_014,
|
|
56
|
+
'СИНЬО ЕДИНСТВО (—)' => 10_786,
|
|
57
|
+
'БКП (—)' => 9_318,
|
|
58
|
+
'ЗЕЛЕНА ПАРТИЯ (—)' => 7_989,
|
|
59
|
+
'Инициативен комитет–Виктор Тенчев Папазов (—)' => 7_652,
|
|
60
|
+
'Инициативен комитет–Румяна Вълчева Угърчинска-Винсенти (—)' \
|
|
61
|
+
=> 7_373,
|
|
62
|
+
'БАСТА (—)' => 7_330,
|
|
63
|
+
'Инициативен комитет–Евгения Златева Банева (—)' => 6_188,
|
|
64
|
+
'ПАРТИЯ НА ЗЕЛЕНИТЕ (—)' => 5_218,
|
|
65
|
+
'СЪЮЗ НА КОМУНИСТИТЕ В БЪЛГАРИЯ (—)' => 3_217,
|
|
66
|
+
'БЪЛГАРСКА НАЦИОНАЛНО-ПАТРИОТИЧНА ПАРТИЯ (—)' => 3_000,
|
|
67
|
+
'Християндемократическа партия на България (—)' => 2_964,
|
|
68
|
+
'Коалиция НАЦИОНАЛИСТИЧЕСКИ ПАРТИИ НА БЪЛГАРИЯ (—)' => 2_499 }
|
|
69
|
+
seats = Sapor::EuropeanUnionBulgaria.instance.seats(results)
|
|
70
|
+
expect(seats['Граждани за европейско развитие на България (EPP)']).to eq(6)
|
|
71
|
+
expect(seats['КОАЛИЦИЯ ЗА БЪЛГАРИЯ (S&D)']).to eq(4)
|
|
72
|
+
expect(seats['Движение за права и свободи (ALDE)']).to eq(4)
|
|
73
|
+
expect(seats['БЪЛГАРИЯ БЕЗ ЦЕНЗУРА, ВМРО, ЗНС, ГЕРГЬОВДЕН (ECR)']).to eq(2)
|
|
74
|
+
expect(seats['РЕФОРМАТОРСКИ БЛОК (EPP)']).to eq(1)
|
|
75
|
+
expect(seats['АЛТЕРНАТИВА ЗА БЪЛГАРСКО ВЪЗРАЖДАНЕ (—)']).to eq(0)
|
|
76
|
+
expect(seats['НАЦИОНАЛЕН ФРОНТ ЗА СПАСЕНИЕ НА БЪЛГАРИЯ (EFDD)']).to eq(0)
|
|
77
|
+
expect(seats['АТАКА (—)']).to eq(0)
|
|
78
|
+
expect(seats['ГЛАС НАРОДЕН (—)']).to eq(0)
|
|
79
|
+
expect(seats['Коалиция КОД–Антония Първанова, Илиана Раева–ОБ, НДСВ, СДП' \
|
|
80
|
+
' (—)']).to eq(0)
|
|
81
|
+
expect(seats['ЗЕЛЕНИТЕ (—)']).to eq(0)
|
|
82
|
+
expect(seats['БЪЛГАРСКАТА ЛЕВИЦА (—)']).to eq(0)
|
|
83
|
+
expect(seats['СИНЬО ЕДИНСТВО (—)']).to eq(0)
|
|
84
|
+
expect(seats['БКП (—)']).to eq(0)
|
|
85
|
+
expect(seats['ЗЕЛЕНА ПАРТИЯ (—)']).to eq(0)
|
|
86
|
+
expect(seats['Инициативен комитет–Виктор Тенчев Папазов (—)']).to eq(0)
|
|
87
|
+
expect(seats['Инициативен комитет–Румяна Вълчева Угърчинска-Винсенти' \
|
|
88
|
+
' (—)']).to eq(0)
|
|
89
|
+
expect(seats['БАСТА (—)']).to eq(0)
|
|
90
|
+
expect(seats['Инициативен комитет–Евгения Златева Банева (—)']).to eq(0)
|
|
91
|
+
expect(seats['ПАРТИЯ НА ЗЕЛЕНИТЕ (—)']).to eq(0)
|
|
92
|
+
expect(seats['СЪЮЗ НА КОМУНИСТИТЕ В БЪЛГАРИЯ (—)']).to eq(0)
|
|
93
|
+
expect(seats['БЪЛГАРСКА НАЦИОНАЛНО-ПАТРИОТИЧНА ПАРТИЯ (—)']).to eq(0)
|
|
94
|
+
expect(seats['Християндемократическа партия на България (—)']).to eq(0)
|
|
95
|
+
expect(seats['Коалиция НАЦИОНАЛИСТИЧЕСКИ ПАРТИИ НА БЪЛГАРИЯ (—)']).to eq(0)
|
|
96
|
+
end
|
|
97
|
+
end
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
#
|
|
3
|
+
# Statistical Analysis of Polling Results (SAPoR)
|
|
4
|
+
# Copyright (C) 2016 Filip van Laenen <f.a.vanlaenen@ieee.org>
|
|
5
|
+
#
|
|
6
|
+
# This file is part of SAPoR.
|
|
7
|
+
#
|
|
8
|
+
# SAPoR is free software: you can redistribute it and/or modify it under the
|
|
9
|
+
# terms of the GNU General Public License as published by the Free Software
|
|
10
|
+
# Foundation, either version 3 of the License, or (at your option) any later
|
|
11
|
+
# version.
|
|
12
|
+
#
|
|
13
|
+
# SAPoR is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
14
|
+
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
15
|
+
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
16
|
+
#
|
|
17
|
+
# You can find a copy of the GNU General Public License in /doc/gpl.txt
|
|
18
|
+
#
|
|
19
|
+
|
|
20
|
+
require 'spec_helper'
|
|
21
|
+
|
|
22
|
+
describe Sapor::EuropeanUnionCroatia, '#area_code' do
|
|
23
|
+
it 'returns EU[HR] as the area code' do
|
|
24
|
+
expect(Sapor::EuropeanUnionCroatia.instance.area_code).to eq('EU[HR]')
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
describe Sapor::EuropeanUnionCroatia, '#no_of_seats' do
|
|
29
|
+
it 'returns 11 as the number of seats' do
|
|
30
|
+
expect(Sapor::EuropeanUnionCroatia.instance.no_of_seats).to eq(11)
|
|
31
|
+
end
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
describe Sapor::EuropeanUnionCroatia, '#population_size' do
|
|
35
|
+
it 'returns a population size of 1,073,954' do
|
|
36
|
+
expect(Sapor::EuropeanUnionCroatia.instance.population_size).to \
|
|
37
|
+
eq(1_073_954)
|
|
38
|
+
end
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
describe Sapor::EuropeanUnionCroatia, '#seats' do
|
|
42
|
+
it 'calculates the number of seats for the election of 2014' do
|
|
43
|
+
results = { 'HDZ-ova koalicija (EPP)' => 381_844,
|
|
44
|
+
'Kukuriku koalicija (S&D)' => 275_904,
|
|
45
|
+
'Održivi razvoj Hrvatske (—)' => 86_806,
|
|
46
|
+
'Savez za Hrvatsku (—)' => 63_437,
|
|
47
|
+
'Hrvatski laburisti–Stranka rada (GUE/NGL)' => 31_363,
|
|
48
|
+
'Partnership of Croatian Center (—)' => 22_098,
|
|
49
|
+
'Others (—)' => 60_452 }
|
|
50
|
+
seats = Sapor::EuropeanUnionCroatia.instance.seats(results)
|
|
51
|
+
expect(seats['HDZ-ova koalicija (EPP)']).to eq(6)
|
|
52
|
+
expect(seats['Kukuriku koalicija (S&D)']).to eq(4)
|
|
53
|
+
expect(seats['Održivi razvoj Hrvatske (—)']).to eq(1)
|
|
54
|
+
expect(seats['Savez za Hrvatsku (—)']).to eq(0)
|
|
55
|
+
expect(seats['Hrvatski laburisti–Stranka rada (GUE/NGL)']).to eq(0)
|
|
56
|
+
expect(seats['Partnership of Croatian Center (—)']).to eq(0)
|
|
57
|
+
expect(seats['Others (—)']).to eq(0)
|
|
58
|
+
end
|
|
59
|
+
end
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
# encoding: utf-8
|
|
2
|
+
#
|
|
3
|
+
# Statistical Analysis of Polling Results (SAPoR)
|
|
4
|
+
# Copyright (C) 2016 Filip van Laenen <f.a.vanlaenen@ieee.org>
|
|
5
|
+
#
|
|
6
|
+
# This file is part of SAPoR.
|
|
7
|
+
#
|
|
8
|
+
# SAPoR is free software: you can redistribute it and/or modify it under the
|
|
9
|
+
# terms of the GNU General Public License as published by the Free Software
|
|
10
|
+
# Foundation, either version 3 of the License, or (at your option) any later
|
|
11
|
+
# version.
|
|
12
|
+
#
|
|
13
|
+
# SAPoR is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
14
|
+
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
|
|
15
|
+
# A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
|
16
|
+
#
|
|
17
|
+
# You can find a copy of the GNU General Public License in /doc/gpl.txt
|
|
18
|
+
#
|
|
19
|
+
|
|
20
|
+
require 'spec_helper'
|
|
21
|
+
|
|
22
|
+
describe Sapor::EuropeanUnionCyprus, '#area_code' do
|
|
23
|
+
it 'returns EU[CY] as the area code' do
|
|
24
|
+
expect(Sapor::EuropeanUnionCyprus.instance.area_code).to eq('EU[CY]')
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
describe Sapor::EuropeanUnionCyprus, '#no_of_seats' do
|
|
29
|
+
it 'returns 6 as the number of seats' do
|
|
30
|
+
expect(Sapor::EuropeanUnionCyprus.instance.no_of_seats).to eq(6)
|
|
31
|
+
end
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
describe Sapor::EuropeanUnionCyprus, '#population_size' do
|
|
35
|
+
it 'returns a population size of 258,914' do
|
|
36
|
+
expect(Sapor::EuropeanUnionCyprus.instance.population_size).to \
|
|
37
|
+
eq(258_914)
|
|
38
|
+
end
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
describe Sapor::EuropeanUnionCyprus, '#seats' do
|
|
42
|
+
it 'calculates the number of seats for the election of 2014' do
|
|
43
|
+
results = { 'Δημοκρατικός Συναγερμός (EPP)' => 97_732,
|
|
44
|
+
'Ανορθωτικό Κόμμα Εργαζόμενου Λαού (GUE/NGL)' => 69_852,
|
|
45
|
+
'Δημοκρατικό Κόμμα (S&D)' => 28_044,
|
|
46
|
+
'Κίνημα Σοσιαλδημοκρατών–Κίνημα Οικολόγων Περιβαλλοντιστών' \
|
|
47
|
+
' (S&D)' => 19_894,
|
|
48
|
+
'Συμμαχία Πολιτών (ALDE)' => 17_549,
|
|
49
|
+
'Μήνυμα Ελπίδας (*)' => 9_907,
|
|
50
|
+
'Εθνικό Λαϊκό Μέτωπο (*)' => 6_957,
|
|
51
|
+
'Κόμμα για τα ζώα Κύπρου (*)' => 2_288,
|
|
52
|
+
'Δικοινοτική Ριζοσπαστική Αριστερή Συνεργασία (*)' => 2_220 }
|
|
53
|
+
seats = Sapor::EuropeanUnionCyprus.instance.seats(results)
|
|
54
|
+
expect(seats['Δημοκρατικός Συναγερμός (EPP)']).to eq(2)
|
|
55
|
+
expect(seats['Ανορθωτικό Κόμμα Εργαζόμενου Λαού (GUE/NGL)']).to eq(2)
|
|
56
|
+
expect(seats['Δημοκρατικό Κόμμα (S&D)']).to eq(1)
|
|
57
|
+
expect(seats['Κίνημα Σοσιαλδημοκρατών–Κίνημα Οικολόγων Περιβαλλοντιστών' \
|
|
58
|
+
' (S&D)']).to eq(1)
|
|
59
|
+
expect(seats['Συμμαχία Πολιτών (ALDE)']).to eq(0)
|
|
60
|
+
expect(seats['Μήνυμα Ελπίδας (*)']).to eq(0)
|
|
61
|
+
expect(seats['Εθνικό Λαϊκό Μέτωπο (*)']).to eq(0)
|
|
62
|
+
expect(seats['Κόμμα για τα ζώα Κύπρου (*)']).to eq(0)
|
|
63
|
+
expect(seats['Δικοινοτική Ριζοσπαστική Αριστερή Συνεργασία (*)']).to eq(0)
|
|
64
|
+
end
|
|
65
|
+
end
|