jiji 1.2.5
Sign up to get free protection for your applications and to get access to all the features.
- data/ChangeLog +58 -0
- data/README +1 -0
- data/base/agents/moving_average_agent.rb +78 -0
- data/base/shared_lib/moving_average.rb +35 -0
- data/base/shared_lib/system/cross.rb +76 -0
- data/base/shared_lib/system/position_manager.rb +160 -0
- data/base/shared_lib/system/signal.rb +347 -0
- data/bin/jiji +5 -0
- data/html/css/calendar.css +432 -0
- data/html/css/datatable.css +299 -0
- data/html/css/default.css +627 -0
- data/html/css/dialog.css +77 -0
- data/html/css/treeview.css +205 -0
- data/html/img/auto_trade_off.gif +0 -0
- data/html/img/auto_trade_on.gif +0 -0
- data/html/img/back_bottom.gif +0 -0
- data/html/img/back_middle.gif +0 -0
- data/html/img/back_top.gif +0 -0
- data/html/img/bin_closed.png +0 -0
- data/html/img/bin_empty.png +0 -0
- data/html/img/bt-create-title-1.gif +0 -0
- data/html/img/bt-create-title-2.gif +0 -0
- data/html/img/bt-create-title-3.gif +0 -0
- data/html/img/button_add.gif +0 -0
- data/html/img/button_add_gray.gif +0 -0
- data/html/img/button_add_over.gif +0 -0
- data/html/img/button_add_small.gif +0 -0
- data/html/img/button_add_small_gray.gif +0 -0
- data/html/img/button_add_small_over.gif +0 -0
- data/html/img/button_apply.gif +0 -0
- data/html/img/button_apply_gray.gif +0 -0
- data/html/img/button_apply_over.gif +0 -0
- data/html/img/button_calendar.gif +0 -0
- data/html/img/button_calendar_over.gif +0 -0
- data/html/img/button_cancel.gif +0 -0
- data/html/img/button_cancel.jpg +0 -0
- data/html/img/button_cancel_gray.gif +0 -0
- data/html/img/button_cancel_over.gif +0 -0
- data/html/img/button_cancel_over.jpg +0 -0
- data/html/img/button_close.gif +0 -0
- data/html/img/button_close_gray.gif +0 -0
- data/html/img/button_close_over.gif +0 -0
- data/html/img/button_mkcol.gif +0 -0
- data/html/img/button_mkcol_gray.gif +0 -0
- data/html/img/button_mkcol_over.gif +0 -0
- data/html/img/button_no.gif +0 -0
- data/html/img/button_no_gray.gif +0 -0
- data/html/img/button_no_over.gif +0 -0
- data/html/img/button_ok.gif +0 -0
- data/html/img/button_ok_gray.gif +0 -0
- data/html/img/button_ok_over.gif +0 -0
- data/html/img/button_remove.gif +0 -0
- data/html/img/button_remove_gray.gif +0 -0
- data/html/img/button_remove_over.gif +0 -0
- data/html/img/button_remove_small.gif +0 -0
- data/html/img/button_remove_small_gray.gif +0 -0
- data/html/img/button_remove_small_over.gif +0 -0
- data/html/img/button_rename.gif +0 -0
- data/html/img/button_rename_gray.gif +0 -0
- data/html/img/button_rename_over.gif +0 -0
- data/html/img/button_save.gif +0 -0
- data/html/img/button_save_gray.gif +0 -0
- data/html/img/button_save_over.gif +0 -0
- data/html/img/button_start.gif +0 -0
- data/html/img/button_start_over.gif +0 -0
- data/html/img/button_update.gif +0 -0
- data/html/img/button_update_gray.gif +0 -0
- data/html/img/button_update_over.gif +0 -0
- data/html/img/button_update_s.gif +0 -0
- data/html/img/button_update_s_gray.gif +0 -0
- data/html/img/button_update_s_over.gif +0 -0
- data/html/img/button_yes.gif +0 -0
- data/html/img/button_yes_gray.gif +0 -0
- data/html/img/button_yes_over.gif +0 -0
- data/html/img/circle.gif +0 -0
- data/html/img/control_play.png +0 -0
- data/html/img/control_play_blue.png +0 -0
- data/html/img/delta.gif +0 -0
- data/html/img/dialog_info.jpg +0 -0
- data/html/img/dialog_input.jpg +0 -0
- data/html/img/dialog_warn.jpg +0 -0
- data/html/img/dt-arrow-dn.png +0 -0
- data/html/img/dt-arrow-up.png +0 -0
- data/html/img/folder.png +0 -0
- data/html/img/folder_brick.png +0 -0
- data/html/img/folder_user.png +0 -0
- data/html/img/foot.jpg +0 -0
- data/html/img/goto.gif +0 -0
- data/html/img/goto_o.gif +0 -0
- data/html/img/h3_bt-create_0.gif +0 -0
- data/html/img/h3_bt-create_1.gif +0 -0
- data/html/img/h3_bt-create_2.gif +0 -0
- data/html/img/h3_result_0.gif +0 -0
- data/html/img/h3_result_1.gif +0 -0
- data/html/img/h3_result_2.gif +0 -0
- data/html/img/h3_result_3.gif +0 -0
- data/html/img/h3_result_4.gif +0 -0
- data/html/img/h3_result_5.gif +0 -0
- data/html/img/h3_result_6.gif +0 -0
- data/html/img/h3_rt-setting_0.gif +0 -0
- data/html/img/h3_rt-setting_1.gif +0 -0
- data/html/img/head.jpg +0 -0
- data/html/img/line-numbers.png +0 -0
- data/html/img/line_white.gif +0 -0
- data/html/img/loading.gif +0 -0
- data/html/img/page_white_ruby.png +0 -0
- data/html/img/panel_100_bottom.gif +0 -0
- data/html/img/panel_100_middle.gif +0 -0
- data/html/img/panel_100_top.gif +0 -0
- data/html/img/panel_140_650_b.gif +0 -0
- data/html/img/panel_140_650_m.gif +0 -0
- data/html/img/panel_140_650_t.gif +0 -0
- data/html/img/panel_140_660_b.gif +0 -0
- data/html/img/panel_140_660_m.gif +0 -0
- data/html/img/panel_140_660_t.gif +0 -0
- data/html/img/panel_140_b.gif +0 -0
- data/html/img/panel_140_m.gif +0 -0
- data/html/img/panel_140_t.gif +0 -0
- data/html/img/panel_260_b.gif +0 -0
- data/html/img/panel_260_m.gif +0 -0
- data/html/img/panel_260_t.gif +0 -0
- data/html/img/panel_300_b.gif +0 -0
- data/html/img/panel_300_m.gif +0 -0
- data/html/img/panel_300_t.gif +0 -0
- data/html/img/panel_320_b.gif +0 -0
- data/html/img/panel_320_m.gif +0 -0
- data/html/img/panel_320_t.gif +0 -0
- data/html/img/panel_360_b.gif +0 -0
- data/html/img/panel_360_m.gif +0 -0
- data/html/img/panel_360_t.gif +0 -0
- data/html/img/panel_380_b.gif +0 -0
- data/html/img/panel_380_m.gif +0 -0
- data/html/img/panel_380_t.gif +0 -0
- data/html/img/panel_500_b.gif +0 -0
- data/html/img/panel_500_m.gif +0 -0
- data/html/img/panel_500_t.gif +0 -0
- data/html/img/panel_620_b.gif +0 -0
- data/html/img/panel_620_m.gif +0 -0
- data/html/img/panel_620_t.gif +0 -0
- data/html/img/panel_780_b.gif +0 -0
- data/html/img/panel_780_m.gif +0 -0
- data/html/img/panel_780_t.gif +0 -0
- data/html/img/problem.gif +0 -0
- data/html/img/progressbar.gif +0 -0
- data/html/img/result-title-1-1.gif +0 -0
- data/html/img/result-title-1-2.gif +0 -0
- data/html/img/result-title-2-1.gif +0 -0
- data/html/img/result-title-2-2.gif +0 -0
- data/html/img/result-title-3-1.gif +0 -0
- data/html/img/result-title-4-1.gif +0 -0
- data/html/img/rt-setting-title-1.gif +0 -0
- data/html/img/rt-setting-title-2.gif +0 -0
- data/html/img/s.gif +0 -0
- data/html/img/scroll.gif +0 -0
- data/html/img/separator.gif +0 -0
- data/html/img/sidebar_agent.png +0 -0
- data/html/img/sidebar_agent_edit.png +0 -0
- data/html/img/sidebar_agent_edit_agent.png +0 -0
- data/html/img/sidebar_agent_edit_agent_over.png +0 -0
- data/html/img/sidebar_agent_edit_agent_s.png +0 -0
- data/html/img/sidebar_agent_edit_over.png +0 -0
- data/html/img/sidebar_agent_edit_s.png +0 -0
- data/html/img/sidebar_agent_edit_shared_lib.png +0 -0
- data/html/img/sidebar_agent_edit_shared_lib_over.png +0 -0
- data/html/img/sidebar_agent_edit_shared_lib_s.png +0 -0
- data/html/img/sidebar_back.gif +0 -0
- data/html/img/sidebar_bt.png +0 -0
- data/html/img/sidebar_bt_create.png +0 -0
- data/html/img/sidebar_bt_create_over.png +0 -0
- data/html/img/sidebar_bt_create_s.png +0 -0
- data/html/img/sidebar_bt_result.png +0 -0
- data/html/img/sidebar_bt_result_over.png +0 -0
- data/html/img/sidebar_bt_result_s.png +0 -0
- data/html/img/sidebar_result_rmt.png +0 -0
- data/html/img/sidebar_result_rmt_over.png +0 -0
- data/html/img/sidebar_result_rmt_s.png +0 -0
- data/html/img/sidebar_rt.png +0 -0
- data/html/img/sidebar_rt_setting.png +0 -0
- data/html/img/sidebar_rt_setting_over.png +0 -0
- data/html/img/sidebar_rt_setting_s.png +0 -0
- data/html/img/sprite.png +0 -0
- data/html/img/submenu_agents.png +0 -0
- data/html/img/submenu_agents_over.png +0 -0
- data/html/img/submenu_agents_s.png +0 -0
- data/html/img/submenu_graph.png +0 -0
- data/html/img/submenu_graph_over.png +0 -0
- data/html/img/submenu_graph_s.png +0 -0
- data/html/img/submenu_info.png +0 -0
- data/html/img/submenu_info_over.png +0 -0
- data/html/img/submenu_info_s.png +0 -0
- data/html/img/submenu_log.png +0 -0
- data/html/img/submenu_log_over.png +0 -0
- data/html/img/submenu_log_s.png +0 -0
- data/html/img/submenu_operation.png +0 -0
- data/html/img/submenu_operation_over.png +0 -0
- data/html/img/submenu_operation_s.png +0 -0
- data/html/img/submenu_trade.png +0 -0
- data/html/img/submenu_trade_over.png +0 -0
- data/html/img/submenu_trade_s.png +0 -0
- data/html/img/td_over.gif +0 -0
- data/html/img/td_over_d.gif +0 -0
- data/html/img/td_selected.gif +0 -0
- data/html/img/thead.gif +0 -0
- data/html/img/transparent.gif +0 -0
- data/html/img/yui/treeview-sprite.gif +0 -0
- data/html/index.html +492 -0
- data/html/js/agent-editor/agent-editor-page.js +324 -0
- data/html/js/agent-editor/agent-editor.js +363 -0
- data/html/js/agent-editor/agent-list-tree.js +251 -0
- data/html/js/agent-selector.js +666 -0
- data/html/js/app.js +198 -0
- data/html/js/bt-create-page.js +205 -0
- data/html/js/container-min.js +1 -0
- data/html/js/container-utils.js +78 -0
- data/html/js/container.js +944 -0
- data/html/js/dialog.js +279 -0
- data/html/js/edit_area/autocompletion.js +491 -0
- data/html/js/edit_area/edit_area.css +546 -0
- data/html/js/edit_area/edit_area.js +539 -0
- data/html/js/edit_area/edit_area_compressor.php +408 -0
- data/html/js/edit_area/edit_area_full.gz +0 -0
- data/html/js/edit_area/edit_area_full.js +38 -0
- data/html/js/edit_area/edit_area_full_with_plugins.gz +0 -0
- data/html/js/edit_area/edit_area_full_with_plugins.js +39 -0
- data/html/js/edit_area/edit_area_functions.js +1205 -0
- data/html/js/edit_area/edit_area_loader.js +1082 -0
- data/html/js/edit_area/elements_functions.js +334 -0
- data/html/js/edit_area/highlight.js +391 -0
- data/html/js/edit_area/images/autocompletion.gif +0 -0
- data/html/js/edit_area/images/close.gif +0 -0
- data/html/js/edit_area/images/fullscreen.gif +0 -0
- data/html/js/edit_area/images/go_to_line.gif +0 -0
- data/html/js/edit_area/images/goto.png +0 -0
- data/html/js/edit_area/images/help.gif +0 -0
- data/html/js/edit_area/images/help.png +0 -0
- data/html/js/edit_area/images/highlight.gif +0 -0
- data/html/js/edit_area/images/load.gif +0 -0
- data/html/js/edit_area/images/move.gif +0 -0
- data/html/js/edit_area/images/newdocument.gif +0 -0
- data/html/js/edit_area/images/opacity.png +0 -0
- data/html/js/edit_area/images/processing.gif +0 -0
- data/html/js/edit_area/images/redo.gif +0 -0
- data/html/js/edit_area/images/redo.png +0 -0
- data/html/js/edit_area/images/reset_highlight.gif +0 -0
- data/html/js/edit_area/images/save.gif +0 -0
- data/html/js/edit_area/images/save.png +0 -0
- data/html/js/edit_area/images/search.gif +0 -0
- data/html/js/edit_area/images/search.png +0 -0
- data/html/js/edit_area/images/smooth_selection.gif +0 -0
- data/html/js/edit_area/images/spacer.gif +0 -0
- data/html/js/edit_area/images/statusbar_resize.gif +0 -0
- data/html/js/edit_area/images/undo.gif +0 -0
- data/html/js/edit_area/images/undo.png +0 -0
- data/html/js/edit_area/images/word_wrap.gif +0 -0
- data/html/js/edit_area/keyboard.js +145 -0
- data/html/js/edit_area/langs/bg.js +73 -0
- data/html/js/edit_area/langs/cs.js +67 -0
- data/html/js/edit_area/langs/de.js +67 -0
- data/html/js/edit_area/langs/dk.js +67 -0
- data/html/js/edit_area/langs/en.js +67 -0
- data/html/js/edit_area/langs/eo.js +67 -0
- data/html/js/edit_area/langs/es.js +64 -0
- data/html/js/edit_area/langs/fi.js +67 -0
- data/html/js/edit_area/langs/fr.js +67 -0
- data/html/js/edit_area/langs/hr.js +67 -0
- data/html/js/edit_area/langs/it.js +67 -0
- data/html/js/edit_area/langs/ja.js +67 -0
- data/html/js/edit_area/langs/mk.js +67 -0
- data/html/js/edit_area/langs/nl.js +67 -0
- data/html/js/edit_area/langs/pl.js +67 -0
- data/html/js/edit_area/langs/pt.js +67 -0
- data/html/js/edit_area/langs/ru.js +67 -0
- data/html/js/edit_area/langs/sk.js +67 -0
- data/html/js/edit_area/langs/zh.js +67 -0
- data/html/js/edit_area/license_apache.txt +7 -0
- data/html/js/edit_area/license_bsd.txt +10 -0
- data/html/js/edit_area/license_lgpl.txt +458 -0
- data/html/js/edit_area/manage_area.js +623 -0
- data/html/js/edit_area/plugins/charmap/charmap.js +90 -0
- data/html/js/edit_area/plugins/charmap/css/charmap.css +64 -0
- data/html/js/edit_area/plugins/charmap/images/charmap.gif +0 -0
- data/html/js/edit_area/plugins/charmap/jscripts/map.js +373 -0
- data/html/js/edit_area/plugins/charmap/langs/bg.js +12 -0
- data/html/js/edit_area/plugins/charmap/langs/cs.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/de.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/dk.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/en.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/eo.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/es.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/fr.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/hr.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/it.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/ja.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/mk.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/nl.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/pl.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/pt.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/ru.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/sk.js +6 -0
- data/html/js/edit_area/plugins/charmap/langs/zh.js +6 -0
- data/html/js/edit_area/plugins/charmap/popup.html +24 -0
- data/html/js/edit_area/plugins/test/css/test.css +3 -0
- data/html/js/edit_area/plugins/test/images/Thumbs.db +0 -0
- data/html/js/edit_area/plugins/test/images/test.gif +0 -0
- data/html/js/edit_area/plugins/test/langs/bg.js +10 -0
- data/html/js/edit_area/plugins/test/langs/cs.js +4 -0
- data/html/js/edit_area/plugins/test/langs/de.js +4 -0
- data/html/js/edit_area/plugins/test/langs/dk.js +4 -0
- data/html/js/edit_area/plugins/test/langs/en.js +4 -0
- data/html/js/edit_area/plugins/test/langs/eo.js +4 -0
- data/html/js/edit_area/plugins/test/langs/es.js +4 -0
- data/html/js/edit_area/plugins/test/langs/fr.js +4 -0
- data/html/js/edit_area/plugins/test/langs/hr.js +4 -0
- data/html/js/edit_area/plugins/test/langs/it.js +4 -0
- data/html/js/edit_area/plugins/test/langs/ja.js +4 -0
- data/html/js/edit_area/plugins/test/langs/mk.js +4 -0
- data/html/js/edit_area/plugins/test/langs/nl.js +4 -0
- data/html/js/edit_area/plugins/test/langs/pl.js +4 -0
- data/html/js/edit_area/plugins/test/langs/pt.js +4 -0
- data/html/js/edit_area/plugins/test/langs/ru.js +4 -0
- data/html/js/edit_area/plugins/test/langs/sk.js +4 -0
- data/html/js/edit_area/plugins/test/langs/zh.js +4 -0
- data/html/js/edit_area/plugins/test/test.js +110 -0
- data/html/js/edit_area/plugins/test/test2.js +1 -0
- data/html/js/edit_area/reg_syntax/basic.js +69 -0
- data/html/js/edit_area/reg_syntax/brainfuck.js +44 -0
- data/html/js/edit_area/reg_syntax/c.js +62 -0
- data/html/js/edit_area/reg_syntax/coldfusion.js +119 -0
- data/html/js/edit_area/reg_syntax/cpp.js +65 -0
- data/html/js/edit_area/reg_syntax/css.js +84 -0
- data/html/js/edit_area/reg_syntax/html.js +50 -0
- data/html/js/edit_area/reg_syntax/java.js +56 -0
- data/html/js/edit_area/reg_syntax/js.js +93 -0
- data/html/js/edit_area/reg_syntax/pas.js +82 -0
- data/html/js/edit_area/reg_syntax/perl.js +88 -0
- data/html/js/edit_area/reg_syntax/php.js +156 -0
- data/html/js/edit_area/reg_syntax/python.js +144 -0
- data/html/js/edit_area/reg_syntax/robotstxt.js +24 -0
- data/html/js/edit_area/reg_syntax/ruby.js +67 -0
- data/html/js/edit_area/reg_syntax/sql.js +55 -0
- data/html/js/edit_area/reg_syntax/tsql.js +87 -0
- data/html/js/edit_area/reg_syntax/vb.js +52 -0
- data/html/js/edit_area/reg_syntax/xml.js +56 -0
- data/html/js/edit_area/reg_syntax.js +166 -0
- data/html/js/edit_area/regexp.js +139 -0
- data/html/js/edit_area/resize_area.js +78 -0
- data/html/js/edit_area/search_replace.js +174 -0
- data/html/js/edit_area/template.html +101 -0
- data/html/js/json-broker-client.js +67 -0
- data/html/js/page-manager.js +93 -0
- data/html/js/prototype.js +4184 -0
- data/html/js/result-page.js +775 -0
- data/html/js/rt-setting-page.js +152 -0
- data/html/js/sidebar.js +263 -0
- data/html/js/templates.js +386 -0
- data/html/js/utils.js +890 -0
- data/html/js/uuid.js +103 -0
- data/html/js/yui/treeview.js +3671 -0
- data/html/swf/chart.swf +0 -0
- data/html/test/agent_editor_spec.js +815 -0
- data/html/test/index.html +40 -0
- data/html/test/jsspec/JSSpec.css +224 -0
- data/html/test/jsspec/JSSpec.js +1549 -0
- data/html/test/jsspec/diff_match_patch.js +1 -0
- data/html/test/utils_spec.js +111 -0
- data/lib/jiji/agent/agent.rb +149 -0
- data/lib/jiji/agent/agent_manager.rb +138 -0
- data/lib/jiji/agent/agent_registry.rb +165 -0
- data/lib/jiji/agent/permitter.rb +128 -0
- data/lib/jiji/agent/util.rb +16 -0
- data/lib/jiji/collector.rb +226 -0
- data/lib/jiji/command.rb +204 -0
- data/lib/jiji/configuration.rb +86 -0
- data/lib/jiji/dao/file_system_dao.rb +158 -0
- data/lib/jiji/dao/rate_dao.rb +149 -0
- data/lib/jiji/dao/timed_data_dao.rb +336 -0
- data/lib/jiji/dao/trade_result_dao.rb +128 -0
- data/lib/jiji/error.rb +49 -0
- data/lib/jiji/migration/migrator.rb +50 -0
- data/lib/jiji/migration/migrator1_0_3.rb +26 -0
- data/lib/jiji/migration/migrator1_1_0.rb +46 -0
- data/lib/jiji/migration/migrator1_2_0.rb +67 -0
- data/lib/jiji/models.rb +223 -0
- data/lib/jiji/observer.rb +105 -0
- data/lib/jiji/operator.rb +396 -0
- data/lib/jiji/output.rb +221 -0
- data/lib/jiji/output_manager.rb +84 -0
- data/lib/jiji/plugin/embedded/click_securities_demo_plugin.rb +141 -0
- data/lib/jiji/plugin/embedded/single_click_client.rb +116 -0
- data/lib/jiji/plugin/plugin_loader.rb +53 -0
- data/lib/jiji/plugin/securities_plugin.rb +134 -0
- data/lib/jiji/process.rb +234 -0
- data/lib/jiji/process_manager.rb +290 -0
- data/lib/jiji/registry.rb +349 -0
- data/lib/jiji/server.rb +127 -0
- data/lib/jiji/service/agent_service.rb +230 -0
- data/lib/jiji/service/hello_service.rb +10 -0
- data/lib/jiji/service/output_service.rb +82 -0
- data/lib/jiji/service/process_service.rb +76 -0
- data/lib/jiji/service/rate_service.rb +38 -0
- data/lib/jiji/service/system_service.rb +14 -0
- data/lib/jiji/service/trade_result_service.rb +31 -0
- data/lib/jiji/util/backtester.rb +116 -0
- data/lib/jiji/util/block_to_session.rb +70 -0
- data/lib/jiji/util/cache.rb +79 -0
- data/lib/jiji/util/csv_append_support.rb +15 -0
- data/lib/jiji/util/file_lock.rb +86 -0
- data/lib/jiji/util/fix_yaml_bug.rb +11 -0
- data/lib/jiji/util/include_proxy.rb +17 -0
- data/lib/jiji/util/iterator.rb +70 -0
- data/lib/jiji/util/json_broker.rb +55 -0
- data/lib/jiji/util/json_rpc_requestor.rb +30 -0
- data/lib/jiji/util/rate_data_importer.rb +219 -0
- data/lib/jiji/util/synchronize_interceptor.rb +41 -0
- data/lib/jiji/util/thread_use_generator.rb +52 -0
- data/lib/jiji/util/util.rb +112 -0
- data/lib/jiji_plugin.rb +6 -0
- data/swf/build.xml +23 -0
- data/swf/chart/FxChart-config.xml +9 -0
- data/swf/chart/FxChart.mxml +17 -0
- data/swf/chart/fx/chart/Chart.as +173 -0
- data/swf/chart/fx/chart/ctrl/AutoUpdate.as +96 -0
- data/swf/chart/fx/chart/ctrl/Controller.as +270 -0
- data/swf/chart/fx/chart/ctrl/Event.as +75 -0
- data/swf/chart/fx/chart/model/Model.as +228 -0
- data/swf/chart/fx/chart/model/TimedData.as +40 -0
- data/swf/chart/fx/chart/ui/AbstractChartUI.as +59 -0
- data/swf/chart/fx/chart/ui/AbstractDrawChartUI.as +63 -0
- data/swf/chart/fx/chart/ui/Constants.as +233 -0
- data/swf/chart/fx/chart/ui/InformationWindow.as +228 -0
- data/swf/chart/fx/chart/ui/LayerManager.as +95 -0
- data/swf/chart/fx/chart/ui/Loading.as +32 -0
- data/swf/chart/fx/chart/ui/Pointer.as +61 -0
- data/swf/chart/fx/chart/ui/RangeInfoWindow.as +84 -0
- data/swf/chart/fx/chart/ui/RenderingContext.as +54 -0
- data/swf/chart/fx/chart/ui/ScaleSelector.as +84 -0
- data/swf/chart/fx/chart/ui/Scroll.as +241 -0
- data/swf/chart/fx/chart/ui/ScrollBar.as +378 -0
- data/swf/chart/fx/chart/ui/Stage.as +97 -0
- data/swf/chart/fx/chart/ui/TradeDetailWindow.as +147 -0
- data/swf/chart/fx/chart/ui/TradeResult.as +330 -0
- data/swf/chart/fx/chart/ui/Window.as +96 -0
- data/swf/chart/fx/chart/ui/candle/Axis.as +112 -0
- data/swf/chart/fx/chart/ui/candle/Candle.as +79 -0
- data/swf/chart/fx/chart/ui/candle/CandleChart.as +81 -0
- data/swf/chart/fx/chart/ui/graph/Graph.as +200 -0
- data/swf/chart/fx/chart/ui/graph/GraphManager.as +192 -0
- data/swf/chart/fx/chart/ui/resource/buy.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/cursor_hand.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/diff_label.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/down.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/down_buy.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/down_buy_1.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/down_buy_2.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/down_buy_3.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/down_sell.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/down_sell_1.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/down_sell_2.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/down_sell_3.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/draw_buy.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/draw_sell.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/end_label.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/fixed.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/loading.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/max_label.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/min_label.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_bar.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_bar_a.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_bar_handle.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_bar_handle_a.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_bar_handle_o.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_bar_left.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_bar_left_a.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_bar_left_o.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_bar_o.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_bar_right.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_bar_right_a.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_bar_right_o.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_handle.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_info_handle.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_left_button.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_left_button_d.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_left_button_down.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_left_button_g.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_left_button_o.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_left_button_up.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_outer.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_outer_left.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_outer_right.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_right_button.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_right_button_d.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_right_button_down.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_right_button_g.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_right_button_o.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_right_button_up.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_slider_left.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/scroll_slider_right.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/sell.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/start_label.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/stripe.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/stripe_b.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/stripe_r.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/unfixed.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/up.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/up_buy.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/up_buy_1.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/up_buy_2.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/up_buy_3.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/up_sell.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/up_sell_1.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/up_sell_2.gif +0 -0
- data/swf/chart/fx/chart/ui/resource/up_sell_3.gif +0 -0
- data/swf/chart/fx/net/StubFactory.as +113 -0
- data/swf/chart/fx/util/ListenerSupport.as +55 -0
- data/swf/chart/fx/util/PositionManager.as +95 -0
- data/swf/chart/fx/util/ScaleFormatter.as +156 -0
- data/swf/chart/fx/util/Util.as +61 -0
- data/swf/chart/log.as +40 -0
- data/swf/lib/corelib.swc +0 -0
- data/test/BackCollectorTest/basic/2008-08-04/AUDJPY.csv +5 -0
- data/test/BackCollectorTest/basic/2008-08-04/USDJPY.csv +5 -0
- data/test/BackCollectorTest/basic/2008-08-04/ZARJPY.csv +5 -0
- data/test/BackCollectorTest/basic/2008-08-05/AUDJPY.csv +5 -0
- data/test/BackCollectorTest/basic/2008-08-05/USDJPY.csv +5 -0
- data/test/BackCollectorTest/basic/2008-08-05/ZARJPY.csv +5 -0
- data/test/BackCollectorTest/basic/2008-08-06/AUDJPY.csv +5 -0
- data/test/BackCollectorTest/basic/2008-08-06/USDJPY.csv +5 -0
- data/test/BackCollectorTest/basic/2008-08-06/ZARJPY.csv +5 -0
- data/test/BackCollectorTest/basic/2008-08-07/AUDJPY.csv +5 -0
- data/test/BackCollectorTest/basic/2008-08-07/USDJPY.csv +5 -0
- data/test/BackCollectorTest/basic/2008-08-07/ZARJPY.csv +5 -0
- data/test/BackCollectorTest/basic/AUDJPY/raw/2008-08-04.csv +5 -0
- data/test/BackCollectorTest/basic/AUDJPY/raw/2008-08-05.csv +5 -0
- data/test/BackCollectorTest/basic/AUDJPY/raw/2008-08-06.csv +5 -0
- data/test/BackCollectorTest/basic/AUDJPY/raw/2008-08-07.csv +5 -0
- data/test/BackCollectorTest/basic/USDJPY/raw/2008-08-04.csv +5 -0
- data/test/BackCollectorTest/basic/USDJPY/raw/2008-08-05.csv +5 -0
- data/test/BackCollectorTest/basic/USDJPY/raw/2008-08-06.csv +5 -0
- data/test/BackCollectorTest/basic/USDJPY/raw/2008-08-07.csv +5 -0
- data/test/BackCollectorTest/basic/ZARJPY/raw/2008-08-04.csv +5 -0
- data/test/BackCollectorTest/basic/ZARJPY/raw/2008-08-05.csv +5 -0
- data/test/BackCollectorTest/basic/ZARJPY/raw/2008-08-06.csv +5 -0
- data/test/BackCollectorTest/basic/ZARJPY/raw/2008-08-07.csv +5 -0
- data/test/BackCollectorTest/lack/2008-08-04/AUDJPY.csv +5 -0
- data/test/BackCollectorTest/lack/2008-08-04/USDJPY.csv +5 -0
- data/test/BackCollectorTest/lack/2008-08-04/ZARJPY.csv +5 -0
- data/test/BackCollectorTest/lack/2008-08-06/AUDJPY.csv +5 -0
- data/test/BackCollectorTest/lack/2008-08-06/USDJPY.csv +5 -0
- data/test/BackCollectorTest/lack/2008-08-06/ZARJPY.csv +5 -0
- data/test/BackCollectorTest/lack/2008-08-07/AUDJPY.csv +5 -0
- data/test/BackCollectorTest/lack/2008-08-07/USDJPY.csv +5 -0
- data/test/BackCollectorTest/lack/2008-08-07/ZARJPY.csv +5 -0
- data/test/BackCollectorTest/lack/AUDJPY/raw/2008-08-04.csv +5 -0
- data/test/BackCollectorTest/lack/AUDJPY/raw/2008-08-06.csv +5 -0
- data/test/BackCollectorTest/lack/AUDJPY/raw/2008-08-07.csv +5 -0
- data/test/BackCollectorTest/lack/USDJPY/raw/2008-08-04.csv +5 -0
- data/test/BackCollectorTest/lack/USDJPY/raw/2008-08-06.csv +5 -0
- data/test/BackCollectorTest/lack/USDJPY/raw/2008-08-07.csv +5 -0
- data/test/BackCollectorTest/lack/ZARJPY/raw/2008-08-04.csv +5 -0
- data/test/BackCollectorTest/lack/ZARJPY/raw/2008-08-06.csv +5 -0
- data/test/BackCollectorTest/lack/ZARJPY/raw/2008-08-07.csv +5 -0
- data/test/OutputregistryTest/conf/configuration.yaml +3 -0
- data/test/ProcessManagerTest/agents/moving_average.rb +95 -0
- data/test/ProcessManagerTest/conf/configuration.yaml +6 -0
- data/test/ProcessManagerTest/rate_datas/EURJPY/raw/2008-08-21.csv +5853 -0
- data/test/ProcessManagerTest/rate_datas/EURJPY/raw/2008-08-22.csv +5821 -0
- data/test/ProcessManagerTest/rate_datas/EURJPY/raw/2008-08-23.csv +5921 -0
- data/test/ProcessManagerTest/rate_datas/EURJPY/raw/2008-08-24.csv +5956 -0
- data/test/ProcessManagerTest/rate_datas/EURJPY/raw/2008-08-25.csv +5796 -0
- data/test/ProcessManagerTest/rate_datas/USDJPY/raw/2008-08-21.csv +5853 -0
- data/test/ProcessManagerTest/rate_datas/USDJPY/raw/2008-08-22.csv +5821 -0
- data/test/ProcessManagerTest/rate_datas/USDJPY/raw/2008-08-23.csv +5921 -0
- data/test/ProcessManagerTest/rate_datas/USDJPY/raw/2008-08-24.csv +5956 -0
- data/test/ProcessManagerTest/rate_datas/USDJPY/raw/2008-08-25.csv +5796 -0
- data/test/ProcessTest/agents/foo.rb +10 -0
- data/test/ProcessTest/conf/configuration.yaml +3 -0
- data/test/agent/agent_tests.rb +10 -0
- data/test/agent/test_AgentManager.rb +321 -0
- data/test/agent/test_AgentRegistry.rb +662 -0
- data/test/agent/test_PeriodicallyAgent.rb +180 -0
- data/test/agent/test_Permitter.rb +217 -0
- data/test/all_tests.rb +24 -0
- data/test/dao/dao_tests.rb +9 -0
- data/test/dao/test_FileSystemDao.rb +431 -0
- data/test/dao/test_RateDao.rb +695 -0
- data/test/dao/test_TradeResultDao.rb +487 -0
- data/test/jiji_plugin.rb +7 -0
- data/test/migration/migration_tests.rb +10 -0
- data/test/migration/migrator1_0_3test_data/rmt/out/M2NlOTA2ODEtZDdlNi00NWU1LWIwNDQtMjBmODY2ZGNkNzBj/56e75YuV5bmz5Z2H57ea/meta.yaml +8 -0
- data/test/migration/migrator1_0_3test_data/rmt/out/NjM5YWFhZmQtNDFjNy00NjUxLWIwYmItNTc3ZjAyZTg5ODA5/56e75YuV5bmz5Z2H57ea/meta.yaml +12 -0
- data/test/migration/migrator1_0_3test_data/rmt/out/NjM5YWFhZmQtNDFjNy00NjUxLWIwYmItNTc3ZjAyZTg5ODA5/56e75Yuasdwqdd/meta.yaml +12 -0
- data/test/migration/migrator1_1_0test_data/configuration.yaml +11 -0
- data/test/migration/migrator1_2_0test_data/basic/out/M2NlOTA2ODEtZDdlNi00NWU1LWIwNDQtMjBmODY2ZGNkNzBj/56e75YuV5bmz5Z2H57ea/1d/2009-04.csv +8 -0
- data/test/migration/migrator1_2_0test_data/basic/out/M2NlOTA2ODEtZDdlNi00NWU1LWIwNDQtMjBmODY2ZGNkNzBj/56e75YuV5bmz5Z2H57ea/meta.yaml +8 -0
- data/test/migration/migrator1_2_0test_data/basic/out/MDVhYzcxMjYtMGFlMS00Mzk0LWEyNmUtYjVjZjgwNDA0ZmE2/56e75YuV5bmz5Z2H57ea/1d/2009-07.csv +1 -0
- data/test/migration/migrator1_2_0test_data/basic/out/MDVhYzcxMjYtMGFlMS00Mzk0LWEyNmUtYjVjZjgwNDA0ZmE2/56e75YuV5bmz5Z2H57ea/meta.yaml +8 -0
- data/test/migration/migrator1_2_0test_data/basic/out/MzA1YTk0NDgtNzhjNi00NDk3LTk2NTktYzE1ZjBhNzdiYjNj/56e75YuV5bmz5Z2H57ea/1d/2009-07.csv +1 -0
- data/test/migration/migrator1_2_0test_data/basic/out/MzA1YTk0NDgtNzhjNi00NDk3LTk2NTktYzE1ZjBhNzdiYjNj/56e75YuV5bmz5Z2H57ea/meta.yaml +8 -0
- data/test/migration/migrator1_2_0test_data/basic/out/YjRkOTI1MzEtZTM4MS00YjQwLTg1ZTQtMWFmZDRlNDUwMzBm/56e75YuV5bmz5Z2H57ea/1d/2009-04.csv +10 -0
- data/test/migration/migrator1_2_0test_data/basic/out/YjRkOTI1MzEtZTM4MS00YjQwLTg1ZTQtMWFmZDRlNDUwMzBm/56e75YuV5bmz5Z2H57ea/1d/2009-05.csv +20 -0
- data/test/migration/migrator1_2_0test_data/basic/out/YjRkOTI1MzEtZTM4MS00YjQwLTg1ZTQtMWFmZDRlNDUwMzBm/56e75YuV5bmz5Z2H57ea/1d/2009-06.csv +20 -0
- data/test/migration/migrator1_2_0test_data/basic/out/YjRkOTI1MzEtZTM4MS00YjQwLTg1ZTQtMWFmZDRlNDUwMzBm/56e75YuV5bmz5Z2H57ea/1d/2009-07.csv +18 -0
- data/test/migration/migrator1_2_0test_data/basic/out/YjRkOTI1MzEtZTM4MS00YjQwLTg1ZTQtMWFmZDRlNDUwMzBm/56e75YuV5bmz5Z2H57ea/meta.yaml +9 -0
- data/test/migration/migrator1_2_0test_data/basic/props.yaml +85 -0
- data/test/migration/migrator1_2_0test_data/illegal_props/out/M2NlOTA2ODEtZDdlNi00NWU1LWIwNDQtMjBmODY2ZGNkNzBj/56e75YuV5bmz5Z2H57ea/1d/2009-04.csv +8 -0
- data/test/migration/migrator1_2_0test_data/illegal_props/out/M2NlOTA2ODEtZDdlNi00NWU1LWIwNDQtMjBmODY2ZGNkNzBj/56e75YuV5bmz5Z2H57ea/meta.yaml +8 -0
- data/test/migration/migrator1_2_0test_data/illegal_props/out/MDVhYzcxMjYtMGFlMS00Mzk0LWEyNmUtYjVjZjgwNDA0ZmE2/56e75YuV5bmz5Z2H57ea/1d/2009-07.csv +1 -0
- data/test/migration/migrator1_2_0test_data/illegal_props/out/MDVhYzcxMjYtMGFlMS00Mzk0LWEyNmUtYjVjZjgwNDA0ZmE2/56e75YuV5bmz5Z2H57ea/meta.yaml +8 -0
- data/test/migration/migrator1_2_0test_data/illegal_props/out/MzA1YTk0NDgtNzhjNi00NDk3LTk2NTktYzE1ZjBhNzdiYjNj/56e75YuV5bmz5Z2H57ea/1d/2009-07.csv +1 -0
- data/test/migration/migrator1_2_0test_data/illegal_props/out/MzA1YTk0NDgtNzhjNi00NDk3LTk2NTktYzE1ZjBhNzdiYjNj/56e75YuV5bmz5Z2H57ea/meta.yaml +8 -0
- data/test/migration/migrator1_2_0test_data/illegal_props/out/YjRkOTI1MzEtZTM4MS00YjQwLTg1ZTQtMWFmZDRlNDUwMzBm/56e75YuV5bmz5Z2H57ea/1d/2009-04.csv +10 -0
- data/test/migration/migrator1_2_0test_data/illegal_props/out/YjRkOTI1MzEtZTM4MS00YjQwLTg1ZTQtMWFmZDRlNDUwMzBm/56e75YuV5bmz5Z2H57ea/1d/2009-05.csv +20 -0
- data/test/migration/migrator1_2_0test_data/illegal_props/out/YjRkOTI1MzEtZTM4MS00YjQwLTg1ZTQtMWFmZDRlNDUwMzBm/56e75YuV5bmz5Z2H57ea/1d/2009-06.csv +20 -0
- data/test/migration/migrator1_2_0test_data/illegal_props/out/YjRkOTI1MzEtZTM4MS00YjQwLTg1ZTQtMWFmZDRlNDUwMzBm/56e75YuV5bmz5Z2H57ea/1d/2009-07.csv +18 -0
- data/test/migration/migrator1_2_0test_data/illegal_props/out/YjRkOTI1MzEtZTM4MS00YjQwLTg1ZTQtMWFmZDRlNDUwMzBm/56e75YuV5bmz5Z2H57ea/meta.yaml +9 -0
- data/test/migration/migrator1_2_0test_data/illegal_props/props.yaml +1 -0
- data/test/migration/migrator1_2_0test_data/no_outs/props.yaml +85 -0
- data/test/migration/migrator1_2_0test_data/no_props/out/M2NlOTA2ODEtZDdlNi00NWU1LWIwNDQtMjBmODY2ZGNkNzBj/56e75YuV5bmz5Z2H57ea/1d/2009-04.csv +8 -0
- data/test/migration/migrator1_2_0test_data/no_props/out/M2NlOTA2ODEtZDdlNi00NWU1LWIwNDQtMjBmODY2ZGNkNzBj/56e75YuV5bmz5Z2H57ea/meta.yaml +8 -0
- data/test/migration/migrator1_2_0test_data/no_props/out/MDVhYzcxMjYtMGFlMS00Mzk0LWEyNmUtYjVjZjgwNDA0ZmE2/56e75YuV5bmz5Z2H57ea/1d/2009-07.csv +1 -0
- data/test/migration/migrator1_2_0test_data/no_props/out/MDVhYzcxMjYtMGFlMS00Mzk0LWEyNmUtYjVjZjgwNDA0ZmE2/56e75YuV5bmz5Z2H57ea/meta.yaml +8 -0
- data/test/migration/migrator1_2_0test_data/no_props/out/MzA1YTk0NDgtNzhjNi00NDk3LTk2NTktYzE1ZjBhNzdiYjNj/56e75YuV5bmz5Z2H57ea/1d/2009-07.csv +1 -0
- data/test/migration/migrator1_2_0test_data/no_props/out/MzA1YTk0NDgtNzhjNi00NDk3LTk2NTktYzE1ZjBhNzdiYjNj/56e75YuV5bmz5Z2H57ea/meta.yaml +8 -0
- data/test/migration/migrator1_2_0test_data/no_props/out/YjRkOTI1MzEtZTM4MS00YjQwLTg1ZTQtMWFmZDRlNDUwMzBm/56e75YuV5bmz5Z2H57ea/1d/2009-04.csv +10 -0
- data/test/migration/migrator1_2_0test_data/no_props/out/YjRkOTI1MzEtZTM4MS00YjQwLTg1ZTQtMWFmZDRlNDUwMzBm/56e75YuV5bmz5Z2H57ea/1d/2009-05.csv +20 -0
- data/test/migration/migrator1_2_0test_data/no_props/out/YjRkOTI1MzEtZTM4MS00YjQwLTg1ZTQtMWFmZDRlNDUwMzBm/56e75YuV5bmz5Z2H57ea/1d/2009-06.csv +20 -0
- data/test/migration/migrator1_2_0test_data/no_props/out/YjRkOTI1MzEtZTM4MS00YjQwLTg1ZTQtMWFmZDRlNDUwMzBm/56e75YuV5bmz5Z2H57ea/1d/2009-07.csv +18 -0
- data/test/migration/migrator1_2_0test_data/no_props/out/YjRkOTI1MzEtZTM4MS00YjQwLTg1ZTQtMWFmZDRlNDUwMzBm/56e75YuV5bmz5Z2H57ea/meta.yaml +9 -0
- data/test/migration/test_Migrator.rb +117 -0
- data/test/migration/test_Migrator1_0_3.rb +118 -0
- data/test/migration/test_Migrator1_1_0.rb +56 -0
- data/test/migration/test_Migrator1_2_0.rb +94 -0
- data/test/plugin/embedded/test_SingleClickClient.rb +144 -0
- data/test/plugin/error_test/jiji_plugin.rb +2 -0
- data/test/plugin/plugin_tests.rb +8 -0
- data/test/plugin/test/foo_plugin.rb +1 -0
- data/test/plugin/test/jiji_plugin.rb +2 -0
- data/test/plugin/test_Loader.rb +33 -0
- data/test/plugin/test_gem/a/jiji_plugin_test_gem_a-1.0.0.gem +0 -0
- data/test/plugin/test_gem/a/jiji_plugin_test_gem_a.gemspec +10 -0
- data/test/plugin/test_gem/a/lib/jiji_plugin.rb +2 -0
- data/test/plugin/test_gem/a/lib/jiji_plugin_test.rb +6 -0
- data/test/plugin/test_gem/b/jiji_plugin_test_gem_b-1.0.0.gem +0 -0
- data/test/plugin/test_gem/b/jiji_plugin_test_gem_b.gemspec +9 -0
- data/test/plugin/test_gem/b/lib/jiji_plugin.rb +2 -0
- data/test/service/all_service_tests.rb +10 -0
- data/test/service/test_AgentService.rb +185 -0
- data/test/service/test_OutputService.rb +33 -0
- data/test/service/test_RateService.rb +56 -0
- data/test/shared/rate.csv +144 -0
- data/test/shared/shared_tests.rb +9 -0
- data/test/shared/test_Cross.rb +144 -0
- data/test/shared/test_PositionManager.rb +285 -0
- data/test/shared/test_Signal.rb +65 -0
- data/test/test_BackTestCollector.rb +273 -0
- data/test/test_Collector.rb +230 -0
- data/test/test_Configuration.rb +61 -0
- data/test/test_Configuration_a.yaml +6 -0
- data/test/test_Operator.rb +501 -0
- data/test/test_Output.rb +175 -0
- data/test/test_OutputManager.rb +162 -0
- data/test/test_Output_registry.rb +42 -0
- data/test/test_Process.rb +557 -0
- data/test/test_ProcessManager.rb +723 -0
- data/test/test_utils.rb +112 -0
- data/test/util/test_BlockToSession.rb +121 -0
- data/test/util/test_CSV.rb +84 -0
- data/test/util/test_SynchronizeInterceptor.rb +76 -0
- data/test/util/util_tests.rb +9 -0
- metadata +941 -0
@@ -0,0 +1,285 @@
|
|
1
|
+
#!/usr/bin/ruby
|
2
|
+
|
3
|
+
$: << "../lib"
|
4
|
+
$: << "../base/shared_lib"
|
5
|
+
|
6
|
+
require 'rubygems'
|
7
|
+
require 'runit/testcase'
|
8
|
+
require 'runit/cui/testrunner'
|
9
|
+
require 'system/position_manager'
|
10
|
+
require 'set'
|
11
|
+
require 'jiji/operator'
|
12
|
+
|
13
|
+
class PositionManagerTest < RUNIT::TestCase
|
14
|
+
|
15
|
+
# 前準備
|
16
|
+
def setup
|
17
|
+
@op = MockOperator.new
|
18
|
+
@pm = PositionManager.new(@op)
|
19
|
+
end
|
20
|
+
|
21
|
+
# 後始末
|
22
|
+
def teardown
|
23
|
+
end
|
24
|
+
|
25
|
+
|
26
|
+
# 基本動作のテスト
|
27
|
+
def test_commit
|
28
|
+
|
29
|
+
assert_equals( @pm.total_profit_or_loss, 0)
|
30
|
+
|
31
|
+
#each
|
32
|
+
assert_equals( @pm.map.size, 0)
|
33
|
+
|
34
|
+
#commit
|
35
|
+
@pm.commit_by {|p| true }
|
36
|
+
assert_equals(@op.commited.size, 0)
|
37
|
+
@op.commited.clear
|
38
|
+
@pm.commit_all
|
39
|
+
assert_equals(@op.commited.size, 0)
|
40
|
+
|
41
|
+
#ポジションを追加
|
42
|
+
ps = [
|
43
|
+
Position.new( 1, 100, JIJI::Position::STATE_START ),
|
44
|
+
Position.new( 2, 200, JIJI::Position::STATE_START ),
|
45
|
+
Position.new( 3, 300, JIJI::Position::STATE_START ),
|
46
|
+
Position.new( 4, 400, JIJI::Position::STATE_START )
|
47
|
+
]
|
48
|
+
ps.each{|p| @op << p }
|
49
|
+
|
50
|
+
assert_equals( @pm.total_profit_or_loss, 1000)
|
51
|
+
|
52
|
+
# each
|
53
|
+
assert_equals( @pm.map.size, 4)
|
54
|
+
|
55
|
+
@pm.commit_by {|p| p.position_id == 1 }
|
56
|
+
assert_equals(@op.commited.size, 1)
|
57
|
+
@pm.commit_all
|
58
|
+
assert_equals(@op.commited.size, 4)
|
59
|
+
end
|
60
|
+
|
61
|
+
# strategyの追加、削除のテスト
|
62
|
+
def test_strategy
|
63
|
+
#ポジションを追加
|
64
|
+
p = Position.new( 1, 0, JIJI::Position::STATE_START )
|
65
|
+
@op << p
|
66
|
+
|
67
|
+
assert( !@pm.registered?(p.position_id) )
|
68
|
+
assert_equals( @pm.get_registered_strategy(p.position_id).size, 0 )
|
69
|
+
|
70
|
+
#損切り対象としてマーク
|
71
|
+
@pm.register_loss_cut( p.position_id, -1000 )
|
72
|
+
@pm.register_trailing_stop( p.position_id, -1000 )
|
73
|
+
@pm.register( p.position_id, Object.new )
|
74
|
+
|
75
|
+
registerd = @pm.get_registered_strategy(p.position_id)
|
76
|
+
assert( @pm.registered?(p.position_id) )
|
77
|
+
assert_equals( registerd.size, 3 )
|
78
|
+
|
79
|
+
#削除
|
80
|
+
@pm.unregister( p.position_id, registerd[1] )
|
81
|
+
assert( @pm.registered?(p.position_id) )
|
82
|
+
assert_equals( @pm.get_registered_strategy(p.position_id).size, 2 )
|
83
|
+
|
84
|
+
@pm.unregister_all( p.position_id )
|
85
|
+
assert( !@pm.registered?(p.position_id) )
|
86
|
+
assert_equals( @pm.get_registered_strategy(p.position_id).size, 0 )
|
87
|
+
|
88
|
+
end
|
89
|
+
|
90
|
+
# losscutのテスト
|
91
|
+
def test_losscut
|
92
|
+
|
93
|
+
#ポジションを追加
|
94
|
+
ps = [
|
95
|
+
Position.new( 1, 0, JIJI::Position::STATE_START ),
|
96
|
+
Position.new( 2, 0, JIJI::Position::STATE_START ),
|
97
|
+
Position.new( 3, 0, JIJI::Position::STATE_START ),
|
98
|
+
Position.new( 4, 0, JIJI::Position::STATE_START )
|
99
|
+
]
|
100
|
+
ps.each{|p| @op << p }
|
101
|
+
|
102
|
+
#損切り対象としてマーク
|
103
|
+
@pm.register_loss_cut( ps[0].position_id, -1000 )
|
104
|
+
@pm.register_loss_cut( ps[1].position_id, -1000 )
|
105
|
+
@pm.register_loss_cut( ps[2].position_id, -1500 )
|
106
|
+
@pm.register_loss_cut( ps[3].position_id, -2000 )
|
107
|
+
ps.each {|p|
|
108
|
+
assert( @pm.registered?(p.position_id) )
|
109
|
+
assert_equals( @pm.get_registered_strategy(p.position_id).size, 1 )
|
110
|
+
}
|
111
|
+
|
112
|
+
# 初回のチェック。何もコミットされない
|
113
|
+
assert_equals( @pm.check, [] )
|
114
|
+
|
115
|
+
# ポジションの損失を-1100に設定
|
116
|
+
ps.each {|p| p.profit_or_loss = -1100 }
|
117
|
+
assert_equals( @pm.check, ps[0..1] ) # 1~2が決済される
|
118
|
+
assert( @op.commited.include?( 1 ) )
|
119
|
+
assert( @op.commited.include?( 2 ) )
|
120
|
+
|
121
|
+
assert( !@pm.registered?(ps[0].position_id) )
|
122
|
+
assert_equals( @pm.get_registered_strategy(ps[0].position_id).size, 0 )
|
123
|
+
assert( !@pm.registered?(ps[1].position_id) )
|
124
|
+
assert_equals( @pm.get_registered_strategy(ps[1].position_id).size, 0 )
|
125
|
+
|
126
|
+
# ポジションの損失を-1500に設定
|
127
|
+
ps.each {|p| p.profit_or_loss = -1500 }
|
128
|
+
assert_equals( @pm.check, [ps[2]] ) # 3が決済される
|
129
|
+
assert( @op.commited.include?( 1 ) )
|
130
|
+
assert( @op.commited.include?( 2 ) )
|
131
|
+
assert( @op.commited.include?( 3 ) )
|
132
|
+
|
133
|
+
assert( !@pm.registered?(ps[2].position_id) )
|
134
|
+
assert_equals( @pm.get_registered_strategy(ps[2].position_id).size, 0 )
|
135
|
+
|
136
|
+
end
|
137
|
+
|
138
|
+
# trailing_stopのテスト
|
139
|
+
def test_trailing_stop
|
140
|
+
|
141
|
+
#ポジションを追加
|
142
|
+
ps = [
|
143
|
+
Position.new( 1, 0, JIJI::Position::STATE_START ),
|
144
|
+
Position.new( 2, 0, JIJI::Position::STATE_START ),
|
145
|
+
Position.new( 3, 0, JIJI::Position::STATE_START ),
|
146
|
+
Position.new( 4, 0, JIJI::Position::STATE_START )
|
147
|
+
]
|
148
|
+
ps.each{|p| @op << p }
|
149
|
+
|
150
|
+
#トレーリングストップの対象としてマーク
|
151
|
+
@pm.register_trailing_stop( ps[0].position_id, -1000 )
|
152
|
+
@pm.register_trailing_stop( ps[1].position_id, -1000 )
|
153
|
+
@pm.register_trailing_stop( ps[2].position_id, -1500 )
|
154
|
+
@pm.register_trailing_stop( ps[3].position_id, -2000 )
|
155
|
+
ps.each {|p|
|
156
|
+
assert( @pm.registered?(p.position_id) )
|
157
|
+
assert_equals( @pm.get_registered_strategy(p.position_id).size, 1 )
|
158
|
+
}
|
159
|
+
|
160
|
+
# 初回のチェック。何もコミットされない
|
161
|
+
assert_equals( @pm.check, [] )
|
162
|
+
|
163
|
+
# ポジションの損失を-1100に設定
|
164
|
+
ps.each {|p| p.profit_or_loss = -1100 }
|
165
|
+
assert_equals( @pm.check, ps[0..1] ) # 1~2が決済される
|
166
|
+
assert( @op.commited.include?( 1 ) )
|
167
|
+
assert( @op.commited.include?( 2 ) )
|
168
|
+
|
169
|
+
assert( !@pm.registered?(ps[0].position_id) )
|
170
|
+
assert_equals( @pm.get_registered_strategy(ps[0].position_id).size, 0 )
|
171
|
+
|
172
|
+
assert( !@pm.registered?(ps[1].position_id) )
|
173
|
+
assert_equals( @pm.get_registered_strategy(ps[1].position_id).size, 0 )
|
174
|
+
|
175
|
+
# ポジションの利益を1500に設定
|
176
|
+
ps.each {|p| p.profit_or_loss = 1500 }
|
177
|
+
assert_equals( @pm.check, [] ) # 決済はされない
|
178
|
+
|
179
|
+
# ポジションの利益を2000に設定
|
180
|
+
ps.each {|p| p.profit_or_loss = 2000 }
|
181
|
+
assert_equals( @pm.check, [] ) # 決済はされない
|
182
|
+
|
183
|
+
# ポジションの利益を500に設定
|
184
|
+
ps.each {|p| p.profit_or_loss = 500 }
|
185
|
+
assert_equals( @pm.check, [ps[2]] ) # 最大値から1500下がったので、3が決済される
|
186
|
+
assert( @op.commited.include?( 1 ) )
|
187
|
+
assert( @op.commited.include?( 2 ) )
|
188
|
+
assert( @op.commited.include?( 3 ) )
|
189
|
+
|
190
|
+
assert( !@pm.registered?(ps[2].position_id) )
|
191
|
+
assert_equals( @pm.get_registered_strategy(ps[2].position_id).size, 0 )
|
192
|
+
|
193
|
+
# ポジションの利益を2500に設定
|
194
|
+
ps.each {|p| p.profit_or_loss = 2500 }
|
195
|
+
assert_equals( @pm.check, [] ) # 決済はされない
|
196
|
+
|
197
|
+
# ポジションの利益を500に設定
|
198
|
+
ps.each {|p| p.profit_or_loss = 500 }
|
199
|
+
assert_equals( @pm.check, [ps[3]] ) # 最大値から1500下がったので、4が決済される
|
200
|
+
assert( @op.commited.include?( 1 ) )
|
201
|
+
assert( @op.commited.include?( 2 ) )
|
202
|
+
assert( @op.commited.include?( 3 ) )
|
203
|
+
assert( @op.commited.include?( 4 ) )
|
204
|
+
|
205
|
+
assert( !@pm.registered?(ps[3].position_id) )
|
206
|
+
assert_equals( @pm.get_registered_strategy(ps[3].position_id).size, 0 )
|
207
|
+
|
208
|
+
end
|
209
|
+
|
210
|
+
# 損切りロジックが複数登録されている場合のテスト
|
211
|
+
def test_multi_stop
|
212
|
+
#ポジションを追加
|
213
|
+
ps = [
|
214
|
+
Position.new( 1, 0, JIJI::Position::STATE_START ),
|
215
|
+
Position.new( 2, 0, JIJI::Position::STATE_START )
|
216
|
+
]
|
217
|
+
ps.each{|p| @op << p }
|
218
|
+
|
219
|
+
# ロスカット
|
220
|
+
@pm.register_loss_cut( ps[0].position_id, -500 )
|
221
|
+
@pm.register_loss_cut( ps[1].position_id, -2000 )
|
222
|
+
|
223
|
+
@pm.register_trailing_stop( ps[0].position_id, -1000 )
|
224
|
+
@pm.register_trailing_stop( ps[1].position_id, -1000 )
|
225
|
+
ps.each {|p|
|
226
|
+
assert( @pm.registered?(p.position_id) )
|
227
|
+
assert_equals( @pm.get_registered_strategy(p.position_id).size, 2 )
|
228
|
+
}
|
229
|
+
|
230
|
+
# 初回のチェック。何もコミットされない
|
231
|
+
assert_equals( @pm.check, [] )
|
232
|
+
|
233
|
+
# ポジションの損失を-200に設定
|
234
|
+
ps.each {|p| p.profit_or_loss = -200 }
|
235
|
+
assert_equals( @pm.check, [] )
|
236
|
+
|
237
|
+
# ポジションの利益を200に設定
|
238
|
+
ps.each {|p| p.profit_or_loss = 200 }
|
239
|
+
assert_equals( @pm.check, [] )
|
240
|
+
|
241
|
+
# ポジションの損失を-500に設定
|
242
|
+
ps.each {|p| p.profit_or_loss = -500 }
|
243
|
+
assert_equals( @pm.check, [ps[0]] ) # 1が決済される
|
244
|
+
assert( @op.commited.include?( 1 ) )
|
245
|
+
|
246
|
+
assert( !@pm.registered?(ps[0].position_id) )
|
247
|
+
assert_equals( @pm.get_registered_strategy(ps[0].position_id).size, 0 )
|
248
|
+
|
249
|
+
# ポジションの利益を1500に設定
|
250
|
+
ps.each {|p| p.profit_or_loss = 1500 }
|
251
|
+
assert_equals( @pm.check, [] ) # 決済はされない
|
252
|
+
|
253
|
+
# ポジションの利益を2000に設定
|
254
|
+
ps.each {|p| p.profit_or_loss = 2000 }
|
255
|
+
assert_equals( @pm.check, [] ) # 決済はされない
|
256
|
+
|
257
|
+
# ポジションの利益を500に設定
|
258
|
+
ps.each {|p| p.profit_or_loss = 1000 }
|
259
|
+
assert_equals( @pm.check, [ps[1]] ) # 最大値から1000下がったので、2が決済される
|
260
|
+
assert( @op.commited.include?( 1 ) )
|
261
|
+
|
262
|
+
assert( !@pm.registered?(ps[1].position_id) )
|
263
|
+
assert_equals( @pm.get_registered_strategy(ps[1].position_id).size, 0 )
|
264
|
+
end
|
265
|
+
|
266
|
+
Position = Struct.new( :position_id, :profit_or_loss, :state )
|
267
|
+
|
268
|
+
# テスト用のダミーoperator
|
269
|
+
class MockOperator
|
270
|
+
def initialize
|
271
|
+
@positions = {}
|
272
|
+
@commited = []
|
273
|
+
end
|
274
|
+
def <<(p)
|
275
|
+
@positions[p.position_id] = p
|
276
|
+
end
|
277
|
+
def commit( position )
|
278
|
+
@commited ||= Set.new
|
279
|
+
@commited << position.position_id
|
280
|
+
@positions.delete position.position_id
|
281
|
+
end
|
282
|
+
attr :commited, true
|
283
|
+
attr :positions, true
|
284
|
+
end
|
285
|
+
end
|
@@ -0,0 +1,65 @@
|
|
1
|
+
#!/usr/bin/ruby
|
2
|
+
|
3
|
+
$: << "../lib"
|
4
|
+
$: << "../base/shared_lib"
|
5
|
+
|
6
|
+
require 'rubygems'
|
7
|
+
require 'runit/testcase'
|
8
|
+
require 'runit/cui/testrunner'
|
9
|
+
require 'system/signal'
|
10
|
+
require 'csv'
|
11
|
+
|
12
|
+
class SignalTest < RUNIT::TestCase
|
13
|
+
|
14
|
+
# 前準備
|
15
|
+
def setup
|
16
|
+
end
|
17
|
+
|
18
|
+
# 後始末
|
19
|
+
def teardown
|
20
|
+
end
|
21
|
+
|
22
|
+
def test_signal
|
23
|
+
signals = [
|
24
|
+
Signal::MovingAverage.new,
|
25
|
+
Signal::WeightedMovingAverage.new,
|
26
|
+
Signal::ExponentialMovingAverage.new,
|
27
|
+
Signal::BollingerBands.new,
|
28
|
+
Signal::BollingerBands.new {|datas| Signal.ema(datas) },
|
29
|
+
Signal::Vector.new,
|
30
|
+
Signal::Momentum.new,
|
31
|
+
Signal::MACD.new,
|
32
|
+
Signal::RSI.new,
|
33
|
+
Signal::ROC.new
|
34
|
+
]
|
35
|
+
signals.each {|s|
|
36
|
+
puts "\n---" + s.class.to_s
|
37
|
+
each {|rate|
|
38
|
+
p s.next_data( rate )
|
39
|
+
}
|
40
|
+
}
|
41
|
+
|
42
|
+
signals = [
|
43
|
+
Signal::DMI.new
|
44
|
+
]
|
45
|
+
signals.each {|s|
|
46
|
+
puts "\n---" + s.class.to_s
|
47
|
+
each_rates {|rate|
|
48
|
+
p s.next_data( rate )
|
49
|
+
}
|
50
|
+
}
|
51
|
+
end
|
52
|
+
|
53
|
+
def each
|
54
|
+
each_rates {|r|
|
55
|
+
yield r.start
|
56
|
+
}
|
57
|
+
end
|
58
|
+
def each_rates( )
|
59
|
+
CSV.foreach( File.dirname(__FILE__) + "/rate.csv" ) {|row|
|
60
|
+
yield Rate.new( row[0].to_f, row[1].to_f, row[2].to_f, row[3].to_f )
|
61
|
+
}
|
62
|
+
end
|
63
|
+
|
64
|
+
Rate = Struct.new( :start, :end, :max, :min )
|
65
|
+
end
|
@@ -0,0 +1,273 @@
|
|
1
|
+
#!/usr/bin/ruby
|
2
|
+
|
3
|
+
$: << "../lib"
|
4
|
+
|
5
|
+
require 'rubygems'
|
6
|
+
require 'runit/testcase'
|
7
|
+
require 'runit/cui/testrunner'
|
8
|
+
require 'jiji/configuration'
|
9
|
+
require 'jiji/collector'
|
10
|
+
require 'jiji/operator'
|
11
|
+
require 'jiji/observer'
|
12
|
+
require 'jiji/plugin/securities_plugin'
|
13
|
+
require 'test_utils'
|
14
|
+
require 'logger'
|
15
|
+
require 'csv'
|
16
|
+
require 'date'
|
17
|
+
|
18
|
+
#BackTestCollectorのテスト
|
19
|
+
#TODO 異常系のテスト
|
20
|
+
class BackTestCollectorTest < RUNIT::TestCase
|
21
|
+
|
22
|
+
include Test::Constants
|
23
|
+
|
24
|
+
# 前準備
|
25
|
+
def setup
|
26
|
+
@dir = File.dirname(__FILE__) + "/BackCollectorTest"
|
27
|
+
|
28
|
+
@logger = Logger.new STDOUT
|
29
|
+
@client = Test::MockClient.new
|
30
|
+
@rate_dao = JIJI::Dao::RateDao.new( @dir )
|
31
|
+
end
|
32
|
+
|
33
|
+
# 後始末
|
34
|
+
def teardown
|
35
|
+
end
|
36
|
+
|
37
|
+
# 通常のログを使ったテスト
|
38
|
+
def test_basic
|
39
|
+
|
40
|
+
# 指定範囲
|
41
|
+
# 存在するデータを内包する値を指定
|
42
|
+
start_date = Time.local( 2008, 8, 4, 20, 50, 0)
|
43
|
+
end_date = Time.local( 2008, 8, 8, 23, 59, 50)
|
44
|
+
c = create_collector( "#{@dir}/basic", start_date, end_date )
|
45
|
+
log = run_collector( c )
|
46
|
+
|
47
|
+
assert_rates log, TIMES_ALL
|
48
|
+
|
49
|
+
# 存在するデータの一定範囲を指定
|
50
|
+
start_date = Time.local( 2008, 8, 5, 23, 59, 40)
|
51
|
+
end_date = Time.local( 2008, 8, 6, 22, 59, 29)
|
52
|
+
c = create_collector( "#{@dir}/basic", start_date, end_date )
|
53
|
+
log = run_collector( c )
|
54
|
+
|
55
|
+
assert_rates log, [
|
56
|
+
Time.local( 2008,8,5,23,59,41),Time.local( 2008,8,5,23,59,51),
|
57
|
+
Time.local( 2008,8,6,21,58,56),Time.local( 2008,8,6,22,59,20)
|
58
|
+
]
|
59
|
+
|
60
|
+
# 開始日時がnull
|
61
|
+
end_date = Time.local( 2008, 8, 6, 0, 0, 0)
|
62
|
+
c = create_collector( "#{@dir}/basic", nil, end_date )
|
63
|
+
log = run_collector( c )
|
64
|
+
|
65
|
+
assert_rates log, TIMES_04+TIMES_05
|
66
|
+
|
67
|
+
|
68
|
+
# 終了日時がnull
|
69
|
+
start_date = Time.local( 2008, 8, 5, 23, 59, 50)
|
70
|
+
c = create_collector( "#{@dir}/basic", start_date, nil )
|
71
|
+
log = run_collector( c )
|
72
|
+
|
73
|
+
assert_rates log, [Time.local( 2008,8,5,23,59,51)]+TIMES_06+TIMES_07
|
74
|
+
|
75
|
+
|
76
|
+
# 開始終了ともにnull
|
77
|
+
c = create_collector( "#{@dir}/basic", nil, nil )
|
78
|
+
log = run_collector( c )
|
79
|
+
|
80
|
+
assert_rates log, TIMES_ALL
|
81
|
+
|
82
|
+
# データがない
|
83
|
+
start_date = Time.local( 2008, 9, 5, 23, 59, 40)
|
84
|
+
end_date = Time.local( 2008, 10, 6, 22, 59, 29)
|
85
|
+
c = create_collector( "#{@dir}/basic", start_date, end_date )
|
86
|
+
log = run_collector( c )
|
87
|
+
assert_equals c.state, :FINISHED
|
88
|
+
|
89
|
+
assert_rates log, []
|
90
|
+
|
91
|
+
# 途中でキャンセル
|
92
|
+
start_date = Time.local( 2008, 7, 5, 23, 59, 40)
|
93
|
+
end_date = Time.local( 2008, 10, 6, 22, 59, 29)
|
94
|
+
c = create_collector( "#{@dir}/basic", start_date, end_date )
|
95
|
+
assert_equals c.state, :WAITING
|
96
|
+
c.start
|
97
|
+
c.stop
|
98
|
+
sleep 0.1 while c.state == :RUNNING
|
99
|
+
assert_equals c.state, :CANCELED
|
100
|
+
|
101
|
+
end
|
102
|
+
|
103
|
+
# 途中に抜けがあるログを使ったテスト
|
104
|
+
def test_lack
|
105
|
+
|
106
|
+
c = create_collector( "#{@dir}/lack", nil, nil )
|
107
|
+
log = run_collector( c )
|
108
|
+
|
109
|
+
assert_rates log, TIMES_04+TIMES_06+TIMES_07
|
110
|
+
end
|
111
|
+
|
112
|
+
#ObserverManagerへの通知でエラーとなった場合のテスト。
|
113
|
+
#エラーがログに通知され、即座にキャンセルとなる。
|
114
|
+
def test_error_ObserverManager
|
115
|
+
|
116
|
+
c = create_collector( "#{@dir}/basic", nil, nil )
|
117
|
+
begin
|
118
|
+
# エラーが発生するようにカスタマイズ
|
119
|
+
class << c.observer_manager
|
120
|
+
def next_rates( rate )
|
121
|
+
raise "test."
|
122
|
+
end
|
123
|
+
end
|
124
|
+
|
125
|
+
assert_equals c.progress, 0
|
126
|
+
assert_equals c.state, :WAITING
|
127
|
+
|
128
|
+
# 取得開始
|
129
|
+
c.start
|
130
|
+
|
131
|
+
sleep 5
|
132
|
+
assert_equals c.state, :ERROR_END # エラーになった場合、即終了
|
133
|
+
assert_equals c.observer_manager.stopped, true # 停止もされる。
|
134
|
+
|
135
|
+
ensure
|
136
|
+
c.stop
|
137
|
+
end
|
138
|
+
end
|
139
|
+
|
140
|
+
#通貨ペアの情報取得でエラーとなった場合のテスト。
|
141
|
+
#エラーがログに通知され、即座にキャンセルとなる。
|
142
|
+
def test_error_GetPairInfo
|
143
|
+
|
144
|
+
c = create_collector( "#{@dir}/basic", nil, nil )
|
145
|
+
begin
|
146
|
+
|
147
|
+
# リクエストの送付でエラーになる。
|
148
|
+
class << c.client
|
149
|
+
def list_pairs
|
150
|
+
raise "test list_rates ."
|
151
|
+
end
|
152
|
+
end
|
153
|
+
|
154
|
+
assert_equals c.progress, 0
|
155
|
+
assert_equals c.state, :WAITING
|
156
|
+
|
157
|
+
# 取得開始
|
158
|
+
c.start
|
159
|
+
|
160
|
+
sleep 5
|
161
|
+
assert_equals c.state, :ERROR_END # エラーになった場合、即終了
|
162
|
+
assert_equals c.observer_manager.stopped, true # 停止もされる。
|
163
|
+
|
164
|
+
ensure
|
165
|
+
c.stop
|
166
|
+
end
|
167
|
+
end
|
168
|
+
|
169
|
+
#レートの取得でエラーとなった場合のテスト。
|
170
|
+
#エラーがログに通知され、即座にキャンセルとなる。
|
171
|
+
def test_error_GetRate
|
172
|
+
|
173
|
+
c = create_collector( "#{@dir}/basic", nil, nil )
|
174
|
+
begin
|
175
|
+
|
176
|
+
# レートの取得でエラーになる。
|
177
|
+
class << c.dao
|
178
|
+
def each_all_pair_rates
|
179
|
+
raise "test each_all_pair_rates ."
|
180
|
+
end
|
181
|
+
end
|
182
|
+
|
183
|
+
assert_equals c.progress, 0
|
184
|
+
assert_equals c.state, :WAITING
|
185
|
+
|
186
|
+
# 取得開始
|
187
|
+
c.start
|
188
|
+
|
189
|
+
sleep 10
|
190
|
+
assert_equals c.state, :ERROR_END # エラーになった場合、即終了
|
191
|
+
assert_equals c.observer_manager.stopped, true # 停止もされる。
|
192
|
+
|
193
|
+
ensure
|
194
|
+
c.stop
|
195
|
+
end
|
196
|
+
end
|
197
|
+
|
198
|
+
|
199
|
+
def create_collector( dir, start_date, end_date )
|
200
|
+
c = JIJI::BackTestCollector.new( JIJI::Dao::RateDao.new( dir ), start_date, end_date )
|
201
|
+
c.logger = @logger
|
202
|
+
c.observer_manager = DummyObserverManager.new
|
203
|
+
c.conf = CONF
|
204
|
+
c.client = @client
|
205
|
+
c
|
206
|
+
end
|
207
|
+
|
208
|
+
def assert_rates( log, times )
|
209
|
+
assert_equals log.length, times.length
|
210
|
+
index = 0
|
211
|
+
log.each {|rates|
|
212
|
+
assert_not_nil rates.pair_infos
|
213
|
+
assert_equals rates.time, times[index]
|
214
|
+
assert_equals rates[:AUDJPY], JIJI::Rate.new( 100.73, 100.78, -189.0, 185.0, rates.time )
|
215
|
+
assert_equals rates[:USDJPY], JIJI::Rate.new( 108.0, 108.01, -65.0, 61.0, rates.time )
|
216
|
+
assert_equals rates[:ZARJPY], JIJI::Rate.new( 14.88, 14.92, -450.0, 420.0, rates.time )
|
217
|
+
index += 1
|
218
|
+
}
|
219
|
+
end
|
220
|
+
|
221
|
+
def run_collector( collector )
|
222
|
+
assert_equals collector.state, :WAITING
|
223
|
+
assert_equals collector.progress, 0
|
224
|
+
collector.start
|
225
|
+
assert_equals collector.state, :RUNNING
|
226
|
+
i=0
|
227
|
+
while collector.state != :FINISHED && i <= 100
|
228
|
+
puts "prgress : #{collector.progress}"
|
229
|
+
sleep 0.1
|
230
|
+
i+=1
|
231
|
+
end
|
232
|
+
assert_equals collector.progress, 100
|
233
|
+
collector.observer_manager.log
|
234
|
+
end
|
235
|
+
|
236
|
+
TIMES_04 = [
|
237
|
+
Time.local( 2008,8,4,21,58,56),Time.local( 2008,8,4,22,59,20),
|
238
|
+
Time.local( 2008,8,4,23,59,30),Time.local( 2008,8,4,23,59,41),
|
239
|
+
Time.local( 2008,8,4,23,59,51)
|
240
|
+
]
|
241
|
+
TIMES_05 = [
|
242
|
+
Time.local( 2008,8,5,21,58,56),Time.local( 2008,8,5,22,59,20),
|
243
|
+
Time.local( 2008,8,5,23,59,30),Time.local( 2008,8,5,23,59,41),
|
244
|
+
Time.local( 2008,8,5,23,59,51)
|
245
|
+
]
|
246
|
+
TIMES_06 = [
|
247
|
+
Time.local( 2008,8,6,21,58,56),Time.local( 2008,8,6,22,59,20),
|
248
|
+
Time.local( 2008,8,6,23,59,30),Time.local( 2008,8,6,23,59,41),
|
249
|
+
Time.local( 2008,8,6,23,59,51)
|
250
|
+
]
|
251
|
+
TIMES_07 = [
|
252
|
+
Time.local( 2008,8,7,21,58,56),Time.local( 2008,8,7,22,59,20),
|
253
|
+
Time.local( 2008,8,7,23,59,30),Time.local( 2008,8,7,23,59,41),
|
254
|
+
Time.local( 2008,8,7,23,59,51)
|
255
|
+
]
|
256
|
+
TIMES_ALL = TIMES_04 + TIMES_05 + TIMES_06 + TIMES_07
|
257
|
+
|
258
|
+
end
|
259
|
+
|
260
|
+
class DummyObserverManager
|
261
|
+
def initialize
|
262
|
+
@log = []
|
263
|
+
@stopped = false
|
264
|
+
end
|
265
|
+
def next_rates( rates )
|
266
|
+
@log << rates
|
267
|
+
end
|
268
|
+
def stop
|
269
|
+
@stopped = true
|
270
|
+
end
|
271
|
+
attr :log, true
|
272
|
+
attr :stopped, true
|
273
|
+
end
|