ramaze.ch.oddb.org 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- data/History.txt +6 -0
- data/LICENSE +339 -0
- data/Manifest.txt +285 -0
- data/README.txt +45 -0
- data/Rakefile +28 -0
- data/bin/admin +69 -0
- data/bin/exportd +63 -0
- data/bin/migrate +461 -0
- data/bin/oddbd +62 -0
- data/data/fulltext/data/dicts/french/fulltext.aff +1057 -0
- data/data/fulltext/data/dicts/french/fulltext.dict +91189 -0
- data/data/fulltext/data/dicts/french/fulltext.stop +135 -0
- data/data/fulltext/data/dicts/german/fulltext.aff +1233 -0
- data/data/fulltext/data/dicts/german/fulltext.dict +287574 -0
- data/data/fulltext/data/dicts/german/fulltext.stop +133 -0
- data/data/fulltext/data/german_compound/README +15 -0
- data/data/fulltext/data/german_compound/compound.pl +63 -0
- data/data/fulltext/data/german_compound/german.stop +20 -0
- data/data/fulltext/data/ispell-german-compound.tar.gz +0 -0
- data/data/fulltext/redist/dict_french/Makefile +12 -0
- data/data/fulltext/redist/dict_french/README.french +1 -0
- data/data/fulltext/redist/dict_french/dict_french.sql.in +7 -0
- data/data/fulltext/redist/dict_french/dict_snowball.c +56 -0
- data/data/fulltext/redist/dict_french/french_stem.c +1222 -0
- data/data/fulltext/redist/dict_french/french_stem.h +16 -0
- data/data/fulltext/redist/dict_french/subinclude.h +2 -0
- data/data/fulltext/redist/dict_german/Makefile +12 -0
- data/data/fulltext/redist/dict_german/README.german +1 -0
- data/data/fulltext/redist/dict_german/dict_german.sql.in +7 -0
- data/data/fulltext/redist/dict_german/dict_snowball.c +56 -0
- data/data/fulltext/redist/dict_german/german_stem.c +527 -0
- data/data/fulltext/redist/dict_german/german_stem.h +16 -0
- data/data/fulltext/redist/dict_german/subinclude.h +1 -0
- data/data/fulltext/redist/french_stem.c +1222 -0
- data/data/fulltext/redist/french_stem.h +16 -0
- data/data/fulltext/redist/german_stem.c +527 -0
- data/data/fulltext/redist/german_stem.h +16 -0
- data/lib/fixes/ruby19.rb +21 -0
- data/lib/fixes/selenium.rb +20 -0
- data/lib/fixes/singular.rb +8 -0
- data/lib/fixes/yaml.rb +13 -0
- data/lib/oddb.rb +11 -0
- data/lib/oddb/business/company.rb +18 -0
- data/lib/oddb/business/invoice.rb +75 -0
- data/lib/oddb/business/price.rb +60 -0
- data/lib/oddb/config.rb +73 -0
- data/lib/oddb/drugs.rb +16 -0
- data/lib/oddb/drugs/active_agent.rb +37 -0
- data/lib/oddb/drugs/atc.rb +53 -0
- data/lib/oddb/drugs/composition.rb +41 -0
- data/lib/oddb/drugs/ddd.rb +24 -0
- data/lib/oddb/drugs/dose.rb +107 -0
- data/lib/oddb/drugs/galenic_form.rb +21 -0
- data/lib/oddb/drugs/galenic_group.rb +17 -0
- data/lib/oddb/drugs/package.rb +87 -0
- data/lib/oddb/drugs/part.rb +56 -0
- data/lib/oddb/drugs/product.rb +25 -0
- data/lib/oddb/drugs/sequence.rb +61 -0
- data/lib/oddb/drugs/substance.rb +31 -0
- data/lib/oddb/drugs/substance_group.rb +13 -0
- data/lib/oddb/drugs/unit.rb +12 -0
- data/lib/oddb/export.rb +4 -0
- data/lib/oddb/export/csv.rb +89 -0
- data/lib/oddb/export/l10n_sessions.rb +30 -0
- data/lib/oddb/export/rss.rb +44 -0
- data/lib/oddb/export/server.rb +58 -0
- data/lib/oddb/export/xls.rb +119 -0
- data/lib/oddb/export/yaml.rb +123 -0
- data/lib/oddb/html/state/drugs/admin/package.rb +189 -0
- data/lib/oddb/html/state/drugs/admin/product.rb +56 -0
- data/lib/oddb/html/state/drugs/admin/sequence.rb +259 -0
- data/lib/oddb/html/state/drugs/ajax/explain_ddd_price.rb +19 -0
- data/lib/oddb/html/state/drugs/ajax/explain_price.rb +19 -0
- data/lib/oddb/html/state/drugs/ajax/global.rb +18 -0
- data/lib/oddb/html/state/drugs/ajax/package_infos.rb +19 -0
- data/lib/oddb/html/state/drugs/ajax/remote_infos.rb +19 -0
- data/lib/oddb/html/state/drugs/atc_browser.rb +39 -0
- data/lib/oddb/html/state/drugs/atc_guidelines.rb +21 -0
- data/lib/oddb/html/state/drugs/compare.rb +52 -0
- data/lib/oddb/html/state/drugs/download_export.rb +18 -0
- data/lib/oddb/html/state/drugs/fachinfo.rb +21 -0
- data/lib/oddb/html/state/drugs/feedback.rb +94 -0
- data/lib/oddb/html/state/drugs/global.rb +266 -0
- data/lib/oddb/html/state/drugs/init.rb +18 -0
- data/lib/oddb/html/state/drugs/login.rb +17 -0
- data/lib/oddb/html/state/drugs/package.rb +32 -0
- data/lib/oddb/html/state/drugs/patinfo.rb +21 -0
- data/lib/oddb/html/state/drugs/products.rb +51 -0
- data/lib/oddb/html/state/drugs/result.rb +125 -0
- data/lib/oddb/html/state/global.rb +165 -0
- data/lib/oddb/html/state/global_predefine.rb +17 -0
- data/lib/oddb/html/state/limit.rb +17 -0
- data/lib/oddb/html/state/login.rb +56 -0
- data/lib/oddb/html/state/paypal/checkout.rb +130 -0
- data/lib/oddb/html/state/paypal/collect.rb +46 -0
- data/lib/oddb/html/state/paypal/redirect.rb +18 -0
- data/lib/oddb/html/state/register_export.rb +38 -0
- data/lib/oddb/html/state/register_poweruser.rb +17 -0
- data/lib/oddb/html/state/viral/admin.rb +76 -0
- data/lib/oddb/html/state/viral/poweruser.rb +16 -0
- data/lib/oddb/html/util/annotated_list.rb +39 -0
- data/lib/oddb/html/util/know_it_all.rb +28 -0
- data/lib/oddb/html/util/known_user.rb +55 -0
- data/lib/oddb/html/util/lookandfeel.rb +554 -0
- data/lib/oddb/html/util/need_all_input.rb +29 -0
- data/lib/oddb/html/util/session.rb +88 -0
- data/lib/oddb/html/util/sort.rb +72 -0
- data/lib/oddb/html/util/unsaved_helper.rb +20 -0
- data/lib/oddb/html/util/validator.rb +54 -0
- data/lib/oddb/html/view/ajax/json.rb +22 -0
- data/lib/oddb/html/view/alpha_header.rb +28 -0
- data/lib/oddb/html/view/document.rb +126 -0
- data/lib/oddb/html/view/drugs/admin/package.rb +237 -0
- data/lib/oddb/html/view/drugs/admin/product.rb +104 -0
- data/lib/oddb/html/view/drugs/admin/sequence.rb +312 -0
- data/lib/oddb/html/view/drugs/ajax/explain_ddd_price.rb +87 -0
- data/lib/oddb/html/view/drugs/ajax/explain_price.rb +61 -0
- data/lib/oddb/html/view/drugs/ajax/package_infos.rb +105 -0
- data/lib/oddb/html/view/drugs/ajax/remote_infos.rb +44 -0
- data/lib/oddb/html/view/drugs/atc_browser.rb +68 -0
- data/lib/oddb/html/view/drugs/atc_guidelines.rb +94 -0
- data/lib/oddb/html/view/drugs/compare.rb +95 -0
- data/lib/oddb/html/view/drugs/download_export.rb +28 -0
- data/lib/oddb/html/view/drugs/fachinfo.rb +46 -0
- data/lib/oddb/html/view/drugs/feedback.rb +231 -0
- data/lib/oddb/html/view/drugs/init.rb +51 -0
- data/lib/oddb/html/view/drugs/legend.rb +24 -0
- data/lib/oddb/html/view/drugs/package.rb +398 -0
- data/lib/oddb/html/view/drugs/patinfo.rb +46 -0
- data/lib/oddb/html/view/drugs/products.rb +97 -0
- data/lib/oddb/html/view/drugs/result.rb +296 -0
- data/lib/oddb/html/view/drugs/search.rb +33 -0
- data/lib/oddb/html/view/drugs/template.rb +15 -0
- data/lib/oddb/html/view/foot.rb +52 -0
- data/lib/oddb/html/view/google.rb +23 -0
- data/lib/oddb/html/view/google_ads.rb +40 -0
- data/lib/oddb/html/view/head.rb +78 -0
- data/lib/oddb/html/view/limit.rb +109 -0
- data/lib/oddb/html/view/list.rb +59 -0
- data/lib/oddb/html/view/login.rb +38 -0
- data/lib/oddb/html/view/navigation.rb +67 -0
- data/lib/oddb/html/view/offset_header.rb +35 -0
- data/lib/oddb/html/view/paypal/collect.rb +84 -0
- data/lib/oddb/html/view/paypal/redirect.rb +51 -0
- data/lib/oddb/html/view/paypal/register_form.rb +106 -0
- data/lib/oddb/html/view/register_export.rb +29 -0
- data/lib/oddb/html/view/register_poweruser.rb +29 -0
- data/lib/oddb/html/view/rss/feedback.rb +64 -0
- data/lib/oddb/html/view/rss_preview.rb +54 -0
- data/lib/oddb/html/view/search.rb +104 -0
- data/lib/oddb/html/view/snapback.rb +24 -0
- data/lib/oddb/html/view/template.rb +56 -0
- data/lib/oddb/import/excel.rb +45 -0
- data/lib/oddb/import/import.rb +39 -0
- data/lib/oddb/import/rtf.rb +410 -0
- data/lib/oddb/import/whocc.rb +173 -0
- data/lib/oddb/import/xml.rb +15 -0
- data/lib/oddb/model.rb +179 -0
- data/lib/oddb/persistence/odba.rb +33 -0
- data/lib/oddb/persistence/odba/business/company.rb +13 -0
- data/lib/oddb/persistence/odba/business/invoice.rb +15 -0
- data/lib/oddb/persistence/odba/drugs/atc.rb +15 -0
- data/lib/oddb/persistence/odba/drugs/galenic_form.rb +18 -0
- data/lib/oddb/persistence/odba/drugs/galenic_group.rb +13 -0
- data/lib/oddb/persistence/odba/drugs/package.rb +25 -0
- data/lib/oddb/persistence/odba/drugs/product.rb +13 -0
- data/lib/oddb/persistence/odba/drugs/sequence.rb +21 -0
- data/lib/oddb/persistence/odba/drugs/substance.rb +21 -0
- data/lib/oddb/persistence/odba/drugs/substance_group.rb +13 -0
- data/lib/oddb/persistence/odba/drugs/unit.rb +13 -0
- data/lib/oddb/persistence/odba/export.rb +26 -0
- data/lib/oddb/persistence/odba/model.rb +68 -0
- data/lib/oddb/persistence/odba/regulatory/authority.rb +13 -0
- data/lib/oddb/persistence/odba/regulatory/registration.rb +13 -0
- data/lib/oddb/persistence/odba/text/document.rb +11 -0
- data/lib/oddb/persistence/odba/util/code.rb +11 -0
- data/lib/oddb/persistence/odba/util/m10l_document.rb +13 -0
- data/lib/oddb/persistence/og.rb +16 -0
- data/lib/oddb/persistence/og/drugs/composition.rb +14 -0
- data/lib/oddb/persistence/og/drugs/product.rb +14 -0
- data/lib/oddb/persistence/og/drugs/sequence.rb +15 -0
- data/lib/oddb/persistence/og/model.rb +25 -0
- data/lib/oddb/persistence/og/util/multilingual.rb +13 -0
- data/lib/oddb/redist/rtf_tools/reader.rb +139 -0
- data/lib/oddb/regulatory/authority.rb +14 -0
- data/lib/oddb/regulatory/registration.rb +15 -0
- data/lib/oddb/remote/business/company.rb +23 -0
- data/lib/oddb/remote/drugs/active_agent.rb +27 -0
- data/lib/oddb/remote/drugs/atc.rb +32 -0
- data/lib/oddb/remote/drugs/dose.rb +8 -0
- data/lib/oddb/remote/drugs/galenic_form.rb +25 -0
- data/lib/oddb/remote/drugs/package.rb +126 -0
- data/lib/oddb/remote/drugs/part.rb +30 -0
- data/lib/oddb/remote/drugs/product.rb +19 -0
- data/lib/oddb/remote/drugs/sequence.rb +46 -0
- data/lib/oddb/remote/drugs/substance.rb +20 -0
- data/lib/oddb/remote/drugs/unit.rb +19 -0
- data/lib/oddb/remote/object.rb +36 -0
- data/lib/oddb/remote/text/document.rb +20 -0
- data/lib/oddb/remote/util/m10l_document.rb +22 -0
- data/lib/oddb/text/chapter.rb +27 -0
- data/lib/oddb/text/document.rb +43 -0
- data/lib/oddb/text/format.rb +37 -0
- data/lib/oddb/text/paragraph.rb +58 -0
- data/lib/oddb/text/picture.rb +93 -0
- data/lib/oddb/text/table.rb +68 -0
- data/lib/oddb/util.rb +8 -0
- data/lib/oddb/util/annotated_list.rb +37 -0
- data/lib/oddb/util/code.rb +69 -0
- data/lib/oddb/util/comparison.rb +36 -0
- data/lib/oddb/util/exporter.rb +8 -0
- data/lib/oddb/util/feedback.rb +23 -0
- data/lib/oddb/util/ipn.rb +48 -0
- data/lib/oddb/util/m10l_document.rb +38 -0
- data/lib/oddb/util/mail.rb +73 -0
- data/lib/oddb/util/money.rb +60 -0
- data/lib/oddb/util/multilingual.rb +70 -0
- data/lib/oddb/util/quanty.rb +4 -0
- data/lib/oddb/util/quanty/fact.rb +229 -0
- data/lib/oddb/util/quanty/main.rb +160 -0
- data/lib/oddb/util/quanty/parse.rb +853 -0
- data/lib/oddb/util/quanty/units.dump +0 -0
- data/lib/oddb/util/server.rb +117 -0
- data/lib/oddb/util/updater.rb +41 -0
- data/lib/oddb/util/ydim.rb +110 -0
- data/lib/oddb/util/yus.rb +46 -0
- data/test/business/test_company.rb +29 -0
- data/test/business/test_price.rb +46 -0
- data/test/drugs/test_active_agent.rb +53 -0
- data/test/drugs/test_atc.rb +54 -0
- data/test/drugs/test_composition.rb +88 -0
- data/test/drugs/test_ddd.rb +22 -0
- data/test/drugs/test_dose.rb +190 -0
- data/test/drugs/test_galenic_form.rb +41 -0
- data/test/drugs/test_package.rb +173 -0
- data/test/drugs/test_part.rb +32 -0
- data/test/drugs/test_product.rb +31 -0
- data/test/drugs/test_sequence.rb +140 -0
- data/test/drugs/test_substance.rb +51 -0
- data/test/drugs/test_substance_group.rb +27 -0
- data/test/export/test_rss.rb +94 -0
- data/test/export/test_server.rb +117 -0
- data/test/export/test_xls.rb +152 -0
- data/test/export/test_yaml.rb +120 -0
- data/test/import/data/html/whocc/A.html +56 -0
- data/test/import/data/html/whocc/A03.html +48 -0
- data/test/import/data/html/whocc/A03AB.html +48 -0
- data/test/import/data/html/whocc/A06AA.html +47 -0
- data/test/import/data/html/whocc/C03.html +47 -0
- data/test/import/data/html/whocc/login.html +77 -0
- data/test/import/data/xml/ATC_2006.xml +47 -0
- data/test/import/data/xml/ATC_2006_ddd.xml +35 -0
- data/test/import/test_excel.rb +34 -0
- data/test/import/test_rtf.rb +40 -0
- data/test/import/test_whocc.rb +315 -0
- data/test/remote/drugs/test_active_agent.rb +36 -0
- data/test/selenium/selenium-server.jar +0 -0
- data/test/selenium/test_atc_browser.rb +122 -0
- data/test/selenium/test_atc_guidelines.rb +96 -0
- data/test/selenium/test_collect.rb +138 -0
- data/test/selenium/test_compare.rb +206 -0
- data/test/selenium/test_fachinfo.rb +130 -0
- data/test/selenium/test_feedback.rb +196 -0
- data/test/selenium/test_init.rb +52 -0
- data/test/selenium/test_limit.rb +305 -0
- data/test/selenium/test_login.rb +67 -0
- data/test/selenium/test_package.rb +512 -0
- data/test/selenium/test_patinfo.rb +131 -0
- data/test/selenium/test_product.rb +80 -0
- data/test/selenium/test_products.rb +142 -0
- data/test/selenium/test_search.rb +715 -0
- data/test/selenium/test_sequence.rb +543 -0
- data/test/selenium/unit.rb +185 -0
- data/test/stub/http_server.rb +169 -0
- data/test/stub/model.rb +173 -0
- data/test/suite.rb +15 -0
- data/test/test_model.rb +83 -0
- data/test/util/test_code.rb +74 -0
- data/test/util/test_ipn.rb +117 -0
- data/test/util/test_mail.rb +86 -0
- data/test/util/test_multilingual.rb +97 -0
- data/test/util/test_server.rb +48 -0
- data/test/util/test_updater.rb +353 -0
- data/test/util/test_ydim.rb +115 -0
- data/test/util/test_yus.rb +79 -0
- metadata +418 -0
@@ -0,0 +1,48 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# Util::TestServer -- de.oddb.org -- 22.11.2006 -- hwyss@ywesee.com
|
3
|
+
|
4
|
+
$: << File.expand_path('../../lib', File.dirname(__FILE__))
|
5
|
+
|
6
|
+
require 'flexmock'
|
7
|
+
require 'test/unit'
|
8
|
+
require 'oddb/util/server'
|
9
|
+
|
10
|
+
module ODDB
|
11
|
+
module Util
|
12
|
+
class TestServer < Test::Unit::TestCase
|
13
|
+
include FlexMock::TestCase
|
14
|
+
def setup
|
15
|
+
ODDB.logger = flexmock('logger')
|
16
|
+
@app = flexmock('app')
|
17
|
+
@server = Server.new(@app)
|
18
|
+
end
|
19
|
+
def test_admin__1
|
20
|
+
@app.should_receive(:foo).and_return(true)
|
21
|
+
result = ''
|
22
|
+
t = @server._admin('foo', result)
|
23
|
+
assert_instance_of(Thread, t)
|
24
|
+
t.join
|
25
|
+
assert_equal('true', result)
|
26
|
+
end
|
27
|
+
def test_admin__2
|
28
|
+
@app.should_receive(:foo).and_return('x'*201)
|
29
|
+
result = ''
|
30
|
+
t = @server._admin('foo', result)
|
31
|
+
assert_instance_of(Thread, t)
|
32
|
+
t.join
|
33
|
+
assert_equal('String', result)
|
34
|
+
end
|
35
|
+
def test_admin__3
|
36
|
+
@app.should_receive(:foo).and_return { raise "some error" }
|
37
|
+
ODDB.logger.should_receive(:error).times(3).and_return { |key, pr|
|
38
|
+
assert_equal('admin', key)
|
39
|
+
}
|
40
|
+
result = ''
|
41
|
+
t = @server._admin('foo', result)
|
42
|
+
assert_instance_of(Thread, t)
|
43
|
+
t.join
|
44
|
+
assert_match("some error", result)
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
@@ -0,0 +1,353 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# Util::TestUpdater -- de.oddb.org -- 05.02.2007 -- hwyss@ywesee.com
|
3
|
+
|
4
|
+
$: << File.expand_path('..', File.dirname(__FILE__))
|
5
|
+
$: << File.expand_path('../../lib', File.dirname(__FILE__))
|
6
|
+
|
7
|
+
require 'test/unit'
|
8
|
+
require 'oddb/util/updater'
|
9
|
+
require 'flexmock'
|
10
|
+
require 'stub/model'
|
11
|
+
|
12
|
+
module ODDB
|
13
|
+
module Util
|
14
|
+
class TestUpdater < Test::Unit::TestCase
|
15
|
+
include FlexMock::TestCase
|
16
|
+
def setup
|
17
|
+
ODDB.config.reset!
|
18
|
+
@config = flexmock(ODDB.config)
|
19
|
+
@var = File.expand_path('var', File.dirname(__FILE__))
|
20
|
+
@data_dir = File.expand_path('data', File.dirname(__FILE__))
|
21
|
+
@xls_dir = File.join(@var, 'xls')
|
22
|
+
FileUtils.rm_r(@xls_dir) if(File.exist?(@xls_dir))
|
23
|
+
@config.should_receive(:var).and_return(@var)
|
24
|
+
@config.should_receive(:data_dir).and_return(@data_dir)
|
25
|
+
@updater = Updater
|
26
|
+
@errors = []
|
27
|
+
ODDB.logger = flexmock('logger')
|
28
|
+
ODDB.logger.should_receive(:error).and_return { |type, block|
|
29
|
+
msg = block.call
|
30
|
+
puts msg
|
31
|
+
@errors.push msg
|
32
|
+
}
|
33
|
+
ODDB.logger.should_ignore_missing
|
34
|
+
end
|
35
|
+
=begin
|
36
|
+
def test_run
|
37
|
+
flexmock(Util::Mail).should_receive(:notify_admins)\
|
38
|
+
.with(String, Array).times(5)
|
39
|
+
arch = File.join(@xls_dir,
|
40
|
+
"Zuzahlungsbefreiung_Excel_080815.XLS")
|
41
|
+
today = Date.new(2006,10)
|
42
|
+
wirkkurz = "ftp://ftp.dimdi.de/pub/amg/wirkkurz_011006.xls"
|
43
|
+
darform = "ftp://ftp.dimdi.de/pub/amg/darform_011006.xls"
|
44
|
+
fbetrag = "ftp://ftp.dimdi.de/pub/amg/fb011006.xls"
|
45
|
+
zuzahlung_index = "http://www.gkv.info/gkv/index.php?id=445"
|
46
|
+
zuzahlung = "http://www.gkv.info/gkv/fileadmin/user_upload/Projekte/arzneimittelzuzahlungsbefreiung/Zuzahlungsbefreiung_Excel_080815.XLS"
|
47
|
+
index_uri = flexmock('Index-URI')
|
48
|
+
index_uri.should_receive(:open)\
|
49
|
+
.times(1).and_return(StringIO.new("xyzfb011006.xlsABC"))
|
50
|
+
wirkkurz_uri = flexmock('Wirkkurz-URI')
|
51
|
+
wirkkurz_uri.should_receive(:open)\
|
52
|
+
.times(1).and_return { |block|
|
53
|
+
block.call StringIO.new("wirkkurz-xls-io")
|
54
|
+
}
|
55
|
+
darform_uri = flexmock('Darform-URI')
|
56
|
+
darform_uri.should_receive(:open)\
|
57
|
+
.times(1).and_return { |block|
|
58
|
+
block.call StringIO.new("darform-xls-io")
|
59
|
+
}
|
60
|
+
fbetrag_uri = flexmock('Festbetrag-URI')
|
61
|
+
fbetrag_uri.should_receive(:open)\
|
62
|
+
.times(1).and_return { |block|
|
63
|
+
block.call StringIO.new("festbetrag-xls-io")
|
64
|
+
}
|
65
|
+
zuzahlung_index_file = File.expand_path('data/html/gkv_index.html',
|
66
|
+
File.dirname(__FILE__))
|
67
|
+
zuzahlung_index_uri = flexmock('Zuzahlungsbefreiung-Index-URI')
|
68
|
+
zuzahlung_index_uri.should_receive(:open)\
|
69
|
+
.times(1).and_return(File.open(zuzahlung_index_file))
|
70
|
+
zuzahlung_uri = flexmock('Zuzahlungsbefreiung-URI')
|
71
|
+
zuzahlung_uri.should_receive(:open)\
|
72
|
+
.times(1).and_return(StringIO.new("zuzahlung-xls-io"))
|
73
|
+
uriparse = flexmock(URI)
|
74
|
+
uriparse.should_receive(:parse).with(Updater::DIMDI_INDEX)\
|
75
|
+
.times(1).and_return(index_uri)
|
76
|
+
uriparse.should_receive(:parse).with(wirkkurz)\
|
77
|
+
.times(1).and_return(wirkkurz_uri)
|
78
|
+
uriparse.should_receive(:parse).with(darform)\
|
79
|
+
.times(1).and_return(darform_uri)
|
80
|
+
uriparse.should_receive(:parse).with(fbetrag)\
|
81
|
+
.times(1).and_return(fbetrag_uri)
|
82
|
+
uriparse.should_receive(:parse).with(zuzahlung_index)\
|
83
|
+
.times(1).and_return(zuzahlung_index_uri)
|
84
|
+
uriparse.should_receive(:parse).with(zuzahlung)\
|
85
|
+
.times(1).and_return(zuzahlung_uri)
|
86
|
+
wirkkurz_import = flexmock('DimdiSubstance')
|
87
|
+
flexmock(Import::Dimdi::Substance)\
|
88
|
+
.should_receive(:new).with(Date.new(2006,10))\
|
89
|
+
.and_return(wirkkurz_import)
|
90
|
+
wirkkurz_import.should_receive(:import)\
|
91
|
+
.times(1).and_return { |io|
|
92
|
+
assert_instance_of(StringIO, io)
|
93
|
+
assert_equal('wirkkurz-xls-io', io.read)
|
94
|
+
[]
|
95
|
+
}
|
96
|
+
darform_import = flexmock('DimdiGalenicForm')
|
97
|
+
flexmock(Import::Dimdi::GalenicForm)\
|
98
|
+
.should_receive(:new).and_return(darform_import)
|
99
|
+
darform_import.should_receive(:import)\
|
100
|
+
.times(1).and_return { |io|
|
101
|
+
assert_instance_of(StringIO, io)
|
102
|
+
assert_equal('darform-xls-io', io.read)
|
103
|
+
[]
|
104
|
+
}
|
105
|
+
fbetrag_import = flexmock('DimdiProduct')
|
106
|
+
flexmock(Import::Dimdi::Product)\
|
107
|
+
.should_receive(:new).and_return(fbetrag_import)
|
108
|
+
fbetrag_import.should_receive(:import)\
|
109
|
+
.times(1).and_return { |io|
|
110
|
+
assert_instance_of(StringIO, io)
|
111
|
+
assert_equal('festbetrag-xls-io', io.read)
|
112
|
+
[]
|
113
|
+
}
|
114
|
+
zuzahl_import = flexmock('DimdiZuzahlungsBefreiung')
|
115
|
+
flexmock(Import::Dimdi::ZuzahlungsBefreiung)\
|
116
|
+
.should_receive(:new).and_return(zuzahl_import)
|
117
|
+
zuzahl_import.should_receive(:import)\
|
118
|
+
.times(1).and_return { |io|
|
119
|
+
assert_instance_of(File, io)
|
120
|
+
assert_equal('zuzahlung-xls-io', io.read)
|
121
|
+
[]
|
122
|
+
}
|
123
|
+
#=begin
|
124
|
+
importer = flexmock('ProductInfos')
|
125
|
+
stub = flexmock(Import::Csv::ProductInfos)
|
126
|
+
stub.should_receive(:download_latest).and_return { |block|
|
127
|
+
block.call('file-handle') }
|
128
|
+
stub.should_receive(:new)\
|
129
|
+
.times(1).and_return(importer)
|
130
|
+
path = File.join(@data_dir, 'csv', 'products.csv')
|
131
|
+
importer.should_receive(:import).with('file-handle')\
|
132
|
+
.times(1).and_return {
|
133
|
+
assert(true)
|
134
|
+
['report']
|
135
|
+
}
|
136
|
+
#=end
|
137
|
+
pharmnet_import = flexmock('PharmNet')
|
138
|
+
flexmock(Import::PharmNet::Import)\
|
139
|
+
.should_receive(:new).and_return(pharmnet_import)
|
140
|
+
pharmnet_import.should_receive(:_import)\
|
141
|
+
.times(1).and_return { |agent, seqs, opts|
|
142
|
+
assert_instance_of(WWW::Mechanize, agent)
|
143
|
+
assert_equal([], seqs)
|
144
|
+
[]
|
145
|
+
}
|
146
|
+
@updater.run(today)
|
147
|
+
assert(File.exist?(File.join(@xls_dir, 'wirkkurz_011006.xls')))
|
148
|
+
assert(File.exist?(File.join(@xls_dir, 'darform_011006.xls')))
|
149
|
+
assert(File.exist?(File.join(@xls_dir, 'fb011006.xls')))
|
150
|
+
assert(File.exist?(arch))
|
151
|
+
assert(File.exist?(File.join(@xls_dir,
|
152
|
+
"2006.10.01-Zuzahlungsbefreiung_Excel_080815.XLS")))
|
153
|
+
end
|
154
|
+
def test_run__errors
|
155
|
+
arch = File.join(@xls_dir,
|
156
|
+
"Zuzahlungsbefreiung_Excel_080815.XLS")
|
157
|
+
today = Date.new(2006,10)
|
158
|
+
wirkkurz = "ftp://ftp.dimdi.de/pub/amg/wirkkurz_011006.xls"
|
159
|
+
darform = "ftp://ftp.dimdi.de/pub/amg/darform_011006.xls"
|
160
|
+
fbetrag = "ftp://ftp.dimdi.de/pub/amg/fb011006.xls"
|
161
|
+
zuzahlung_index = "http://www.gkv.info/gkv/index.php?id=445"
|
162
|
+
zuzahlung = "http://www.gkv.info/gkv/fileadmin/user_upload/Projekte/arzneimittelzuzahlungsbefreiung/Zuzahlungsbefreiung_Excel_080815.XLS"
|
163
|
+
index_uri = flexmock('Index-URI')
|
164
|
+
index_uri.should_receive(:open)\
|
165
|
+
.times(1).and_return(StringIO.new("xyzfb011006.xlsABC"))
|
166
|
+
wirkkurz_uri = flexmock('Wirkkurz-URI')
|
167
|
+
wirkkurz_uri.should_receive(:open)\
|
168
|
+
.times(1).and_return {
|
169
|
+
raise "connection error 1"
|
170
|
+
}
|
171
|
+
darform_uri = flexmock('Darform-URI')
|
172
|
+
darform_uri.should_receive(:open)\
|
173
|
+
.times(1).and_return {
|
174
|
+
raise "connection error 2"
|
175
|
+
}
|
176
|
+
fbetrag_uri = flexmock('Festbetrag-URI')
|
177
|
+
fbetrag_uri.should_receive(:open)\
|
178
|
+
.times(1).and_return {
|
179
|
+
raise "connection error 3"
|
180
|
+
}
|
181
|
+
zuzahlung_index_file = File.expand_path('data/html/gkv_index.html',
|
182
|
+
File.dirname(__FILE__))
|
183
|
+
zuzahlung_index_uri = flexmock('Zuzahlungsbefreiung-Index-URI')
|
184
|
+
zuzahlung_index_uri.should_receive(:open)\
|
185
|
+
.times(1).and_return(File.open(zuzahlung_index_file))
|
186
|
+
zuzahlung_uri = flexmock('Zuzahlungsbefreiung-URI')
|
187
|
+
zuzahlung_uri.should_receive(:open)\
|
188
|
+
.times(1).and_return {
|
189
|
+
raise "connection error 4"
|
190
|
+
}
|
191
|
+
stub = flexmock(Net::POP3)
|
192
|
+
stub.should_receive(:start).and_return {
|
193
|
+
raise "connection error 5"
|
194
|
+
}
|
195
|
+
flexmock(Import::PharmNet::Import).new_instances\
|
196
|
+
.should_receive(:_import)\
|
197
|
+
.times(1).and_return { |agent, seqs, opts|
|
198
|
+
raise "import error"
|
199
|
+
}
|
200
|
+
uriparse = flexmock(URI)
|
201
|
+
uriparse.should_receive(:parse).with(Updater::DIMDI_INDEX)\
|
202
|
+
.times(1).and_return(index_uri)
|
203
|
+
uriparse.should_receive(:parse).with(wirkkurz)\
|
204
|
+
.times(1).and_return(wirkkurz_uri)
|
205
|
+
uriparse.should_receive(:parse).with(darform)\
|
206
|
+
.times(1).and_return(darform_uri)
|
207
|
+
uriparse.should_receive(:parse).with(fbetrag)\
|
208
|
+
.times(1).and_return(fbetrag_uri)
|
209
|
+
uriparse.should_receive(:parse).with(zuzahlung_index)\
|
210
|
+
.times(1).and_return(zuzahlung_index_uri)
|
211
|
+
uriparse.should_receive(:parse).with(zuzahlung)\
|
212
|
+
.times(1).and_return(zuzahlung_uri)
|
213
|
+
flexmock(Util::Mail).should_receive(:notify_admins).times(1)
|
214
|
+
assert_nothing_raised {
|
215
|
+
@updater.run(today)
|
216
|
+
}
|
217
|
+
assert(!File.exist?(File.join(@xls_dir, 'wirkkurz_011006.xls')))
|
218
|
+
assert(!File.exist?(File.join(@xls_dir, 'darform_011006.xls')))
|
219
|
+
assert(!File.exist?(File.join(@xls_dir, 'fb011006.xls')))
|
220
|
+
assert(!File.exist?(arch))
|
221
|
+
end
|
222
|
+
def test_run__later_errors
|
223
|
+
flexmock(Util::Mail).should_receive(:notify_admins)\
|
224
|
+
.with(String, Array).times(5)
|
225
|
+
arch = File.join(@xls_dir,
|
226
|
+
"Zuzahlungsbefreiung_Excel_080815.XLS")
|
227
|
+
today = Date.new(2006,10)
|
228
|
+
wirkkurz = "ftp://ftp.dimdi.de/pub/amg/wirkkurz_011006.xls"
|
229
|
+
darform = "ftp://ftp.dimdi.de/pub/amg/darform_011006.xls"
|
230
|
+
fbetrag = "ftp://ftp.dimdi.de/pub/amg/fb011006.xls"
|
231
|
+
zuzahlung_index = "http://www.gkv.info/gkv/index.php?id=445"
|
232
|
+
zuzahlung = "http://www.gkv.info/gkv/fileadmin/user_upload/Projekte/arzneimittelzuzahlungsbefreiung/Zuzahlungsbefreiung_Excel_080815.XLS"
|
233
|
+
index_uri = flexmock('Index-URI')
|
234
|
+
index_uri.should_receive(:open)\
|
235
|
+
.times(1).and_return(StringIO.new("xyzfb011006.xlsABC"))
|
236
|
+
wirkkurz_uri = flexmock('Wirkkurz-URI')
|
237
|
+
wirkkurz_uri.should_receive(:open)\
|
238
|
+
.times(1).and_return { |block|
|
239
|
+
block.call StringIO.new("wirkkurz-xls-io")
|
240
|
+
}
|
241
|
+
darform_uri = flexmock('Darform-URI')
|
242
|
+
darform_uri.should_receive(:open)\
|
243
|
+
.times(1).and_return { |block|
|
244
|
+
block.call StringIO.new("darform-xls-io")
|
245
|
+
}
|
246
|
+
fbetrag_uri = flexmock('Festbetrag-URI')
|
247
|
+
fbetrag_uri.should_receive(:open)\
|
248
|
+
.times(1).and_return { |block|
|
249
|
+
block.call StringIO.new("festbetrag-xls-io")
|
250
|
+
}
|
251
|
+
zuzahlung_index_file = File.expand_path('data/html/gkv_index.html',
|
252
|
+
File.dirname(__FILE__))
|
253
|
+
zuzahlung_index_uri = flexmock('Zuzahlungsbefreiung-Index-URI')
|
254
|
+
zuzahlung_index_uri.should_receive(:open)\
|
255
|
+
.times(1).and_return(File.open(zuzahlung_index_file))
|
256
|
+
zuzahlung_uri = flexmock('Zuzahlungsbefreiung-URI')
|
257
|
+
zuzahlung_uri.should_receive(:open)\
|
258
|
+
.times(1).and_return(StringIO.new("zuzahlung-xls-io"))
|
259
|
+
uriparse = flexmock(URI)
|
260
|
+
uriparse.should_receive(:parse).with(Updater::DIMDI_INDEX)\
|
261
|
+
.times(1).and_return(index_uri)
|
262
|
+
uriparse.should_receive(:parse).with(wirkkurz)\
|
263
|
+
.times(1).and_return(wirkkurz_uri)
|
264
|
+
uriparse.should_receive(:parse).with(darform)\
|
265
|
+
.times(1).and_return(darform_uri)
|
266
|
+
uriparse.should_receive(:parse).with(fbetrag)\
|
267
|
+
.times(1).and_return(fbetrag_uri)
|
268
|
+
uriparse.should_receive(:parse).with(zuzahlung_index)\
|
269
|
+
.times(1).and_return(zuzahlung_index_uri)
|
270
|
+
uriparse.should_receive(:parse).with(zuzahlung)\
|
271
|
+
.times(1).and_return(zuzahlung_uri)
|
272
|
+
wirkkurz_import = flexmock('DimdiSubstance')
|
273
|
+
flexmock(Import::Dimdi::Substance)\
|
274
|
+
.should_receive(:new).with(Date.new(2006,10))\
|
275
|
+
.and_return(wirkkurz_import)
|
276
|
+
wirkkurz_import.should_receive(:import)\
|
277
|
+
.times(1).and_return { |io|
|
278
|
+
assert_instance_of(StringIO, io)
|
279
|
+
assert_equal('wirkkurz-xls-io', io.read)
|
280
|
+
raise "import error"
|
281
|
+
}
|
282
|
+
darform_import = flexmock('DimdiGalenicForm')
|
283
|
+
flexmock(Import::Dimdi::GalenicForm)\
|
284
|
+
.should_receive(:new).and_return(darform_import)
|
285
|
+
darform_import.should_receive(:import)\
|
286
|
+
.times(1).and_return { |io|
|
287
|
+
assert_instance_of(StringIO, io)
|
288
|
+
assert_equal('darform-xls-io', io.read)
|
289
|
+
raise "import error"
|
290
|
+
}
|
291
|
+
fbetrag_import = flexmock('DimdiProduct')
|
292
|
+
flexmock(Import::Dimdi::Product)\
|
293
|
+
.should_receive(:new).and_return(fbetrag_import)
|
294
|
+
fbetrag_import.should_receive(:import)\
|
295
|
+
.times(1).and_return { |io|
|
296
|
+
assert_instance_of(StringIO, io)
|
297
|
+
assert_equal('festbetrag-xls-io', io.read)
|
298
|
+
raise "import error"
|
299
|
+
}
|
300
|
+
zuzahl_import = flexmock('DimdiZuzahlungsBefreiung')
|
301
|
+
flexmock(Import::Dimdi::ZuzahlungsBefreiung)\
|
302
|
+
.should_receive(:new).and_return(zuzahl_import)
|
303
|
+
zuzahl_import.should_receive(:import)\
|
304
|
+
.times(1).and_return { |io|
|
305
|
+
assert_instance_of(File, io)
|
306
|
+
assert_equal('zuzahlung-xls-io', io.read)
|
307
|
+
raise "import error"
|
308
|
+
}
|
309
|
+
#=begin
|
310
|
+
importer = flexmock('ProductInfos')
|
311
|
+
stub = flexmock(Import::Csv::ProductInfos)
|
312
|
+
stub.should_receive(:download_latest).and_return { |block|
|
313
|
+
block.call('file-handle') rescue StandardError }
|
314
|
+
stub.should_receive(:new)\
|
315
|
+
.times(1).and_return(importer)
|
316
|
+
path = File.join(@data_dir, 'csv', 'products.csv')
|
317
|
+
importer.should_receive(:import).with('file-handle')\
|
318
|
+
.times(1).and_return { |io|
|
319
|
+
assert_equal('file-handle', io)
|
320
|
+
raise "import error"
|
321
|
+
}
|
322
|
+
#=end
|
323
|
+
flexmock(Import::PharmNet::Import).new_instances\
|
324
|
+
.should_receive(:_import)\
|
325
|
+
.times(1).and_return { |agent, seqs, opts|
|
326
|
+
raise "import error"
|
327
|
+
}
|
328
|
+
assert_nothing_raised {
|
329
|
+
@updater.run(today)
|
330
|
+
}
|
331
|
+
assert(!File.exist?(File.join(@xls_dir, 'wirkkurz_011006.xls')))
|
332
|
+
assert(!File.exist?(File.join(@xls_dir, 'darform_011006.xls')))
|
333
|
+
assert(!File.exist?(File.join(@xls_dir, 'fb011006.xls')))
|
334
|
+
assert(!File.exist?(File.join(@xls_dir,
|
335
|
+
"Zuzahlungsbefreiung_Excel_080815.XLS")))
|
336
|
+
end
|
337
|
+
=end
|
338
|
+
def test_import_whocc_guidelines
|
339
|
+
flexmock(Util::Mail).should_receive(:notify_admins)\
|
340
|
+
.with(String, Array).times(1)
|
341
|
+
importer = flexmock('Guidelines')
|
342
|
+
flexmock(Import::Whocc::Guidelines).should_receive(:new)\
|
343
|
+
.times(1).and_return(importer)
|
344
|
+
importer.should_receive(:import).with(WWW::Mechanize)\
|
345
|
+
.times(1).and_return {
|
346
|
+
assert(true)
|
347
|
+
['report']
|
348
|
+
}
|
349
|
+
Updater.import_whocc_guidelines
|
350
|
+
end
|
351
|
+
end
|
352
|
+
end
|
353
|
+
end
|
@@ -0,0 +1,115 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# Util::TestYdim -- de.oddb.org -- 04.02.2008 -- hwyss@ywesee.com
|
3
|
+
|
4
|
+
|
5
|
+
$: << File.expand_path('../../lib', File.dirname(__FILE__))
|
6
|
+
|
7
|
+
require 'flexmock'
|
8
|
+
require 'test/unit'
|
9
|
+
require 'oddb/business/invoice'
|
10
|
+
require 'oddb/util/ydim'
|
11
|
+
|
12
|
+
module ODDB
|
13
|
+
module Util
|
14
|
+
class TestYdim < Test::Unit::TestCase
|
15
|
+
include FlexMock::TestCase
|
16
|
+
def setup
|
17
|
+
@client = flexmock('ydim-client')
|
18
|
+
@ydim = flexmock(YDIM::Client).new_instances
|
19
|
+
@ydim.should_receive(:login)
|
20
|
+
@drb_ydim = DRb.start_service('druby://localhost:0', @ydim)
|
21
|
+
YDIM::Client::CONFIG.server_url = @drb_ydim.uri
|
22
|
+
@yus = flexmock(Util::Yus)
|
23
|
+
super
|
24
|
+
end
|
25
|
+
def teardown
|
26
|
+
@drb_ydim.stop_service
|
27
|
+
super
|
28
|
+
end
|
29
|
+
def setup_ydim_invoice(unique_id, description)
|
30
|
+
invoice = flexmock('ydim-invoice')
|
31
|
+
invoice.should_receive(:description=).with(description)
|
32
|
+
invoice.should_receive(:date=).with(Date.today)
|
33
|
+
invoice.should_receive(:currency=).with('EUR')
|
34
|
+
invoice.should_receive(:payment_period=).with(30)
|
35
|
+
invoice.should_receive(:unique_id).and_return unique_id
|
36
|
+
invoice.should_receive(:payment_received=).with(true)
|
37
|
+
invoice.should_receive(:save).times(1)
|
38
|
+
invoice
|
39
|
+
end
|
40
|
+
def test_inject__old_invoice
|
41
|
+
invoice = Business::Invoice.new
|
42
|
+
invoice.ydim_id = 123
|
43
|
+
invoice.yus_name = 'test@invoice.com'
|
44
|
+
invoice.add(:poweruser, "unlimited access", 365, "Tage", 2)
|
45
|
+
ydim_inv = flexmock('remote invoice')
|
46
|
+
@ydim.should_receive(:invoice).with(123).and_return ydim_inv
|
47
|
+
assert_equal ydim_inv, Ydim.inject(invoice)
|
48
|
+
end
|
49
|
+
def test_inject__new_invoice
|
50
|
+
invoice = Business::Invoice.new
|
51
|
+
invoice.yus_name = 'test@invoice.com'
|
52
|
+
item = invoice.add(:poweruser, "unlimited access", 365, "Tage", 2)
|
53
|
+
item.expiry_time = exp = Time.now + 365 * 24 * 60 * 60
|
54
|
+
|
55
|
+
@yus.should_receive(:get_preference).with('test@invoice.com', :ydim_id)\
|
56
|
+
.and_return 158
|
57
|
+
@yus.should_receive(:set_preference).with('test@invoice.com', :ydim_id, 158)
|
58
|
+
|
59
|
+
today = Date.today
|
60
|
+
next_year = (today >> 12)
|
61
|
+
descr = "PowerUser ch.oddb.org #{today.strftime("%d.%m.%Y")} - #{next_year.strftime("%d.%m.%Y")}"
|
62
|
+
ydim_inv = setup_ydim_invoice(1234, descr)
|
63
|
+
@ydim.should_receive(:create_invoice).with(158).and_return { ydim_inv }
|
64
|
+
expected = [
|
65
|
+
{ :unit => "Tage", :text => "unlimited access",
|
66
|
+
:expiry_time => exp, :quantity => 365, :price => 2.0,
|
67
|
+
:time => item.time } ]
|
68
|
+
@ydim.should_receive(:add_items).with(1234, expected)
|
69
|
+
|
70
|
+
assert_equal ydim_inv, Ydim.inject(invoice, :payment_received => true)
|
71
|
+
end
|
72
|
+
def test_debitor_id__old_customer_by_id
|
73
|
+
@yus.should_receive(:get_preference).with('test@invoice.com', :ydim_id)\
|
74
|
+
.and_return 158
|
75
|
+
assert_equal(158, Ydim.debitor_id('test@invoice.com'))
|
76
|
+
end
|
77
|
+
def test_debitor_id__old_customer_by_email
|
78
|
+
@yus.should_receive(:get_preference).with('test@invoice.com', :ydim_id)\
|
79
|
+
.and_return nil
|
80
|
+
debitor = flexmock('debitor')
|
81
|
+
debitor.should_receive(:unique_id).and_return(158)
|
82
|
+
@ydim.should_receive(:search_debitors).with('test@invoice.com')\
|
83
|
+
.and_return { [debitor] }
|
84
|
+
assert_equal(158, Ydim.debitor_id('test@invoice.com'))
|
85
|
+
end
|
86
|
+
def test_debitor_id__new_customer
|
87
|
+
@yus.should_receive(:get_preference).with('test@invoice.com', :ydim_id)\
|
88
|
+
.and_return nil
|
89
|
+
debitor = flexmock('debitor')
|
90
|
+
debitor.should_receive(:unique_id).and_return(158)
|
91
|
+
@ydim.should_receive(:search_debitors).with('test@invoice.com')\
|
92
|
+
.and_return { [] }
|
93
|
+
ydim_debitor = flexmock('ydim-debitor')
|
94
|
+
keys = [ :salutation, :name_last, :name_first ]
|
95
|
+
@yus.should_receive(:get_preferences).with('test@invoice.com', keys)\
|
96
|
+
.and_return {
|
97
|
+
{ :salutation => 'salutation_m',
|
98
|
+
:name_last => 'Test',
|
99
|
+
:name_first => 'Fred',
|
100
|
+
}
|
101
|
+
}
|
102
|
+
@ydim.should_receive(:create_debitor).and_return(ydim_debitor)
|
103
|
+
ydim_debitor.should_receive(:salutation=).with('Herr')
|
104
|
+
ydim_debitor.should_receive(:contact_firstname=).with('Fred')
|
105
|
+
ydim_debitor.should_receive(:contact=).with('Test')
|
106
|
+
ydim_debitor.should_receive(:debitor_type=).with('dt_info')
|
107
|
+
ydim_debitor.should_receive(:email=).with('test@invoice.com')
|
108
|
+
ydim_debitor.should_receive(:save)
|
109
|
+
ydim_debitor.should_receive(:unique_id).and_return 158
|
110
|
+
|
111
|
+
assert_equal(158, Ydim.debitor_id('test@invoice.com'))
|
112
|
+
end
|
113
|
+
end
|
114
|
+
end
|
115
|
+
end
|