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,723 @@
|
|
1
|
+
#!/usr/bin/ruby
|
2
|
+
|
3
|
+
$: << "../lib"
|
4
|
+
|
5
|
+
|
6
|
+
#clazz = class << Thread; self; end
|
7
|
+
#clazz.__send__(:alias_method, :start_org, :start )
|
8
|
+
#def Thread.start(*args, &b)
|
9
|
+
# Thread.start_org( caller, *args) {|stack, *arg|
|
10
|
+
# Thread.current[:stack] = stack
|
11
|
+
# yield( *arg )
|
12
|
+
# }
|
13
|
+
#end
|
14
|
+
#def Thread.fork(*args, &b)
|
15
|
+
# Thread.start_org( caller, *args) {|stack, *arg|
|
16
|
+
# Thread.current[:stack] = stack
|
17
|
+
# yield( *arg )
|
18
|
+
# }
|
19
|
+
#end
|
20
|
+
#def Thread.new(*args, &b)
|
21
|
+
# Thread.start_org( caller, *args) {|stack, *arg|
|
22
|
+
# Thread.current[:stack] = stack
|
23
|
+
# yield( *arg )
|
24
|
+
# }
|
25
|
+
#end
|
26
|
+
|
27
|
+
require 'runit/testcase'
|
28
|
+
require 'runit/cui/testrunner'
|
29
|
+
require 'jiji/registry'
|
30
|
+
require 'logger'
|
31
|
+
require 'test_utils'
|
32
|
+
|
33
|
+
# プロセスマネージャのテスト
|
34
|
+
class ProcessManagerTest < RUNIT::TestCase
|
35
|
+
|
36
|
+
include Test::Constants
|
37
|
+
|
38
|
+
def setup
|
39
|
+
@dir = File.dirname(__FILE__) + "/ProcessManagerTest"
|
40
|
+
FileUtils.rm_rf "#{@dir}/logs"
|
41
|
+
FileUtils.rm_rf "#{@dir}/process_logs"
|
42
|
+
@registry = JIJI::Registry.new(@dir , nil)
|
43
|
+
@registry.plugin_loader.load
|
44
|
+
@mng = @registry[:process_manager]
|
45
|
+
@omng = @registry[:output_manager]
|
46
|
+
end
|
47
|
+
|
48
|
+
def teardown
|
49
|
+
Test.destry( @registry, nil )
|
50
|
+
FileUtils.rm_rf "#{@dir}/logs"
|
51
|
+
FileUtils.rm_rf "#{@dir}/process_logs"
|
52
|
+
# Thread.list.each {|t|
|
53
|
+
# puts "---#{t}"
|
54
|
+
# puts t[:stack]
|
55
|
+
# }
|
56
|
+
end
|
57
|
+
|
58
|
+
def test_basic
|
59
|
+
@mng.start
|
60
|
+
agents = [{
|
61
|
+
"name" => "aaa",
|
62
|
+
"class" => "MovingAverageAgent@moving_average.rb",
|
63
|
+
"id"=> "44c0d256-8994-4240-a6c6-8d9546aef8c4",
|
64
|
+
"properties" => {
|
65
|
+
"period" => 10,
|
66
|
+
"short" => 25,
|
67
|
+
"long" => 75
|
68
|
+
}
|
69
|
+
}]
|
70
|
+
|
71
|
+
# プロセスを追加
|
72
|
+
pid = @mng.create_back_test( "test", "memo", Time.gm( 2008, 8, 21 ).to_i, Time.gm( 2008, 8, 22 ).to_i, agents )["id"]
|
73
|
+
sleep 0.1
|
74
|
+
|
75
|
+
# プロセスを取得
|
76
|
+
process = @mng.get( pid )
|
77
|
+
assert_equals process["state"], :RUNNING
|
78
|
+
assert_not_nil process.progress
|
79
|
+
assert_equals process.process_id, pid
|
80
|
+
assert_equals process["name"], "test"
|
81
|
+
assert_equals process["memo"], "memo"
|
82
|
+
assert_equals process["start_date"], Time.gm( 2008, 8, 21 ).to_i
|
83
|
+
assert_equals process["end_date"], Time.gm( 2008, 8, 22 ).to_i
|
84
|
+
assert_not_nil process["create_date"]
|
85
|
+
|
86
|
+
# 実行完了を待つ
|
87
|
+
sleep 1 while @mng.get( pid )["state"] == :RUNNING
|
88
|
+
|
89
|
+
assert_equals process["state"], :FINISHED
|
90
|
+
assert_not_nil process.progress
|
91
|
+
assert_equals process.process_id, pid
|
92
|
+
assert_equals process["name"], "test"
|
93
|
+
assert_equals process["memo"], "memo"
|
94
|
+
assert_equals process["start_date"], Time.gm( 2008, 8, 21 ).to_i
|
95
|
+
assert_equals process["end_date"], Time.gm( 2008, 8, 22 ).to_i
|
96
|
+
assert_not_nil process["create_date"]
|
97
|
+
|
98
|
+
#別のプロセスを追加
|
99
|
+
pid2 = @mng.create_back_test( "test2", "memo", Time.gm( 2008, 8, 21 ).to_i, Time.gm( 2008, 8, 22 ).to_i, agents )["id"]
|
100
|
+
sleep 1
|
101
|
+
|
102
|
+
process = @mng.get( pid )
|
103
|
+
assert_equals process["state"], :FINISHED
|
104
|
+
assert_not_nil process.progress
|
105
|
+
assert_equals process.process_id, pid
|
106
|
+
assert_equals process["name"], "test"
|
107
|
+
assert_equals process["memo"], "memo"
|
108
|
+
assert_equals process["start_date"], Time.gm( 2008, 8, 21 ).to_i
|
109
|
+
assert_equals process["end_date"], Time.gm( 2008, 8, 22 ).to_i
|
110
|
+
assert_not_nil process["create_date"]
|
111
|
+
|
112
|
+
process = @mng.get( pid2 )
|
113
|
+
assert_equals process["state"], :RUNNING
|
114
|
+
assert_not_nil process.progress
|
115
|
+
assert_equals process.process_id, pid2
|
116
|
+
assert_equals process["name"], "test2"
|
117
|
+
assert_equals process["memo"], "memo"
|
118
|
+
assert_equals process["start_date"], Time.gm( 2008, 8, 21 ).to_i
|
119
|
+
assert_equals process["end_date"], Time.gm( 2008, 8, 22 ).to_i
|
120
|
+
assert_not_nil process["create_date"]
|
121
|
+
|
122
|
+
# 停止
|
123
|
+
@mng.stop
|
124
|
+
|
125
|
+
process = @mng.get( pid )
|
126
|
+
assert_equals process["state"], :FINISHED
|
127
|
+
assert_not_nil process.progress
|
128
|
+
assert_equals process.process_id, pid
|
129
|
+
assert_equals process["name"], "test"
|
130
|
+
assert_equals process["memo"], "memo"
|
131
|
+
assert_equals process["start_date"], Time.gm( 2008, 8, 21 ).to_i
|
132
|
+
assert_equals process["end_date"], Time.gm( 2008, 8, 22 ).to_i
|
133
|
+
assert_not_nil process["create_date"]
|
134
|
+
|
135
|
+
process = @mng.get( pid2 )
|
136
|
+
assert_equals process["state"], :CANCELED
|
137
|
+
assert_not_nil process.progress
|
138
|
+
assert_equals process.process_id, pid2
|
139
|
+
assert_equals process["name"], "test2"
|
140
|
+
assert_equals process["memo"], "memo"
|
141
|
+
assert_equals process["start_date"], Time.gm( 2008, 8, 21 ).to_i
|
142
|
+
assert_equals process["end_date"], Time.gm( 2008, 8, 22 ).to_i
|
143
|
+
assert_not_nil process["create_date"]
|
144
|
+
|
145
|
+
|
146
|
+
# マネージャを再作成 / プロセスがローカルのファイルより復元される
|
147
|
+
recreate_registry
|
148
|
+
@mng = @registry[:process_manager]
|
149
|
+
|
150
|
+
process = @mng.get( pid )
|
151
|
+
assert_equals process["state"], :FINISHED
|
152
|
+
assert_not_nil process.progress
|
153
|
+
assert_equals process.process_id, pid
|
154
|
+
assert_equals process["name"], "test"
|
155
|
+
assert_equals process["memo"], "memo"
|
156
|
+
assert_equals process["start_date"], Time.gm( 2008, 8, 21 ).to_i
|
157
|
+
assert_equals process["end_date"], Time.gm( 2008, 8, 22 ).to_i
|
158
|
+
assert_not_nil process["create_date"]
|
159
|
+
|
160
|
+
process = @mng.get( pid2 )
|
161
|
+
assert_equals process["state"], :CANCELED
|
162
|
+
assert_not_nil process.progress
|
163
|
+
assert_equals process.process_id, pid2
|
164
|
+
assert_equals process["name"], "test2"
|
165
|
+
assert_equals process["memo"], "memo"
|
166
|
+
assert_equals process["start_date"], Time.gm( 2008, 8, 21 ).to_i
|
167
|
+
assert_equals process["end_date"], Time.gm( 2008, 8, 22 ).to_i
|
168
|
+
assert_not_nil process["create_date"]
|
169
|
+
|
170
|
+
|
171
|
+
# プロセスを削除
|
172
|
+
@mng.delete_back_test( pid )
|
173
|
+
assert_process_not_found(pid)
|
174
|
+
|
175
|
+
process = @mng.get( pid2 )
|
176
|
+
assert_equals process["state"], :CANCELED
|
177
|
+
assert_not_nil process.progress
|
178
|
+
assert_equals process.process_id, pid2
|
179
|
+
assert_equals process["name"], "test2"
|
180
|
+
assert_equals process["memo"], "memo"
|
181
|
+
assert_equals process["start_date"], Time.gm( 2008, 8, 21 ).to_i
|
182
|
+
assert_equals process["end_date"], Time.gm( 2008, 8, 22 ).to_i
|
183
|
+
assert_not_nil process["create_date"]
|
184
|
+
|
185
|
+
@mng.delete_back_test( pid2 )
|
186
|
+
assert_process_not_found(pid2)
|
187
|
+
|
188
|
+
# マネージャを再作成 / 削除されたデータは消えている筈
|
189
|
+
recreate_registry
|
190
|
+
@mng = @registry[:process_manager]
|
191
|
+
|
192
|
+
assert_process_not_found(pid)
|
193
|
+
assert_process_not_found(pid2)
|
194
|
+
|
195
|
+
# 実行中に削除
|
196
|
+
pid3 = @mng.create_back_test( "test3", "memo", Time.gm( 2008, 8, 21 ).to_i, Time.gm( 2008, 8, 22 ).to_i, agents )["id"]
|
197
|
+
sleep 0.1
|
198
|
+
|
199
|
+
process = @mng.get( pid3 )
|
200
|
+
assert_equals process["state"], :RUNNING
|
201
|
+
assert_not_nil process.progress
|
202
|
+
assert_equals process.process_id, pid3
|
203
|
+
assert_equals process["name"], "test3"
|
204
|
+
assert_equals process["memo"], "memo"
|
205
|
+
assert_equals process["start_date"], Time.gm( 2008, 8, 21 ).to_i
|
206
|
+
assert_equals process["end_date"], Time.gm( 2008, 8, 22 ).to_i
|
207
|
+
assert_not_nil process["create_date"]
|
208
|
+
|
209
|
+
@mng.delete_back_test( pid3 )
|
210
|
+
assert_process_not_found(pid3)
|
211
|
+
|
212
|
+
# マネージャを再作成 / 削除されたデータは消えている筈
|
213
|
+
recreate_registry
|
214
|
+
@mng = @registry[:process_manager]
|
215
|
+
assert_process_not_found(pid3)
|
216
|
+
|
217
|
+
end
|
218
|
+
|
219
|
+
#
|
220
|
+
#複数プロセスを同時に起動するテスト。
|
221
|
+
#
|
222
|
+
def test_multi_process
|
223
|
+
@mng.start
|
224
|
+
agents = [{
|
225
|
+
"name" => "aaa",
|
226
|
+
"class" => "MovingAverageAgent@moving_average.rb",
|
227
|
+
"id"=> "44c0d256-8994-4240-a6c6-8d9546aef8c4",
|
228
|
+
"properties" => {
|
229
|
+
"period" => 10,
|
230
|
+
"short" => 25,
|
231
|
+
"long" => 75
|
232
|
+
}
|
233
|
+
}]
|
234
|
+
|
235
|
+
# プロセスを追加
|
236
|
+
pid = @mng.create_back_test( "test", "memo", Time.gm( 2008, 8, 21 ).to_i, Time.gm( 2008, 8, 22 ).to_i, agents )["id"]
|
237
|
+
sleep 1
|
238
|
+
|
239
|
+
# プロセスを取得
|
240
|
+
process = @mng.get( pid )
|
241
|
+
assert_equals process["state"], :RUNNING
|
242
|
+
assert_not_nil process.progress
|
243
|
+
assert_equals process.process_id, pid
|
244
|
+
|
245
|
+
#別のプロセスを追加
|
246
|
+
pid2 = @mng.create_back_test( "test2", "memo", Time.gm( 2008, 8, 21 ).to_i, Time.gm( 2008, 8, 22 ).to_i, agents )["id"]
|
247
|
+
sleep 1
|
248
|
+
|
249
|
+
#別のプロセスは待機中になる。
|
250
|
+
process = @mng.get( pid2 )
|
251
|
+
assert_equals process["state"], :WAITING
|
252
|
+
assert_not_nil process.progress
|
253
|
+
assert_equals process.process_id, pid2
|
254
|
+
|
255
|
+
process = @mng.get( pid )
|
256
|
+
assert_equals process["state"], :RUNNING
|
257
|
+
assert_not_nil process.progress
|
258
|
+
assert_equals process.process_id, pid
|
259
|
+
|
260
|
+
# 実行完了を待つ
|
261
|
+
sleep 1 while @mng.get( pid )["state"] == :RUNNING
|
262
|
+
|
263
|
+
process = @mng.get( pid )
|
264
|
+
assert_equals process["state"], :FINISHED
|
265
|
+
assert_not_nil process.progress
|
266
|
+
assert_equals process.process_id, pid
|
267
|
+
|
268
|
+
sleep 1
|
269
|
+
|
270
|
+
#別のプロセスが開始される。
|
271
|
+
process = @mng.get( pid2 )
|
272
|
+
assert_equals process["state"], :RUNNING
|
273
|
+
assert_not_nil process.progress
|
274
|
+
assert_equals process.process_id, pid2
|
275
|
+
|
276
|
+
# 別のプロセスを追加して削除
|
277
|
+
pid3 = @mng.create_back_test( "test3", "memo", Time.gm( 2008, 8, 21 ).to_i, Time.gm( 2008, 8, 22 ).to_i, agents )["id"]
|
278
|
+
sleep 1
|
279
|
+
process = @mng.get( pid3 )
|
280
|
+
assert_equals process["state"], :WAITING
|
281
|
+
assert_not_nil process.progress
|
282
|
+
assert_equals process.process_id, pid3
|
283
|
+
|
284
|
+
@mng.delete_back_test( pid3 )
|
285
|
+
assert_process_not_found(pid3)
|
286
|
+
|
287
|
+
sleep 1 while @mng.get( pid2 )["state"] == :RUNNING
|
288
|
+
|
289
|
+
process = @mng.get( pid2 )
|
290
|
+
assert_equals process["state"], :FINISHED
|
291
|
+
assert_not_nil process.progress
|
292
|
+
assert_equals process.process_id, pid2
|
293
|
+
|
294
|
+
sleep 10
|
295
|
+
|
296
|
+
## 待機状態のまま再起動
|
297
|
+
# プロセスを追加
|
298
|
+
pid4 = @mng.create_back_test( "test4", "memo", Time.gm( 2008, 8, 21 ).to_i, Time.gm( 2008, 8, 22 ).to_i, agents )["id"]
|
299
|
+
sleep 10
|
300
|
+
|
301
|
+
#別のプロセスを追加
|
302
|
+
pid5 = @mng.create_back_test( "test5", "memo", Time.gm( 2008, 8, 21 ).to_i, Time.gm( 2008, 8, 22 ).to_i, agents )["id"]
|
303
|
+
|
304
|
+
process = @mng.get( pid4 )
|
305
|
+
assert_equals process["state"], :RUNNING
|
306
|
+
assert_not_nil process.progress
|
307
|
+
assert_equals process.process_id, pid4
|
308
|
+
|
309
|
+
process = @mng.get( pid5 )
|
310
|
+
assert_equals process["state"], :WAITING
|
311
|
+
assert_not_nil process.progress
|
312
|
+
assert_equals process.process_id, pid5
|
313
|
+
|
314
|
+
recreate_registry
|
315
|
+
@mng = @registry[:process_manager]
|
316
|
+
|
317
|
+
# 実行中のものも待機中のものもキャンセル状態になる。
|
318
|
+
process = @mng.get( pid4 )
|
319
|
+
assert_equals process["state"], :CANCELED
|
320
|
+
assert_not_nil process.progress
|
321
|
+
assert_equals process.process_id, pid4
|
322
|
+
|
323
|
+
process = @mng.get( pid5)
|
324
|
+
assert_equals process["state"], :CANCELED
|
325
|
+
assert_not_nil process.progress
|
326
|
+
assert_equals process.process_id, pid5
|
327
|
+
end
|
328
|
+
|
329
|
+
#リスタートのテスト。
|
330
|
+
def test_restart
|
331
|
+
@mng.start
|
332
|
+
agents = [{
|
333
|
+
"name" => "aaa",
|
334
|
+
"class" => "MovingAverageAgent@moving_average.rb",
|
335
|
+
"id"=> "44c0d256-8994-4240-a6c6-8d9546aef8c4",
|
336
|
+
"properties" => {
|
337
|
+
"period" => 10,
|
338
|
+
"short" => 25,
|
339
|
+
"long" => 75
|
340
|
+
}
|
341
|
+
}]
|
342
|
+
|
343
|
+
# プロセスを追加
|
344
|
+
pid = @mng.create_back_test( "test", "memo", Time.gm( 2008, 8, 21 ).to_i, Time.gm( 2008, 8, 22 ).to_i, agents )["id"]
|
345
|
+
sleep 1
|
346
|
+
process = @mng.get( pid )
|
347
|
+
assert_equals process["state"], :RUNNING
|
348
|
+
assert_not_nil process.progress
|
349
|
+
|
350
|
+
# 実行完了を待つ
|
351
|
+
sleep 1 while @mng.get( pid )["state"] == :RUNNING
|
352
|
+
process = @mng.get( pid )
|
353
|
+
assert_equals process["state"], :FINISHED
|
354
|
+
assert_not_nil process.progress
|
355
|
+
|
356
|
+
#再起動
|
357
|
+
pid = @mng.restart_test( pid )["id"]
|
358
|
+
sleep 1
|
359
|
+
process = @mng.get( pid )
|
360
|
+
assert_equals process["state"], :RUNNING
|
361
|
+
assert_not_nil process.progress
|
362
|
+
|
363
|
+
#別のプロセスを追加
|
364
|
+
pid2 = @mng.create_back_test( "test2", "memo", Time.gm( 2008, 8, 21 ).to_i, Time.gm( 2008, 8, 22 ).to_i, agents )["id"]
|
365
|
+
sleep 1
|
366
|
+
|
367
|
+
#別のプロセスは待機中になる。
|
368
|
+
process = @mng.get( pid2 )
|
369
|
+
assert_equals process["state"], :WAITING
|
370
|
+
assert_not_nil process.progress
|
371
|
+
|
372
|
+
process = @mng.get( pid )
|
373
|
+
assert_equals process["state"], :RUNNING
|
374
|
+
assert_not_nil process.progress
|
375
|
+
|
376
|
+
|
377
|
+
# 実行完了を待つ
|
378
|
+
sleep 1 while @mng.get( pid )["state"] == :RUNNING
|
379
|
+
|
380
|
+
process = @mng.get( pid )
|
381
|
+
assert_equals process["state"], :FINISHED
|
382
|
+
assert_not_nil process.progress
|
383
|
+
|
384
|
+
sleep 1
|
385
|
+
|
386
|
+
#別のプロセスが開始される。
|
387
|
+
process = @mng.get( pid2 )
|
388
|
+
assert_equals process["state"], :RUNNING
|
389
|
+
assert_not_nil process.progress
|
390
|
+
assert_equals process.process_id, pid2
|
391
|
+
|
392
|
+
|
393
|
+
#再起動 / プロセスpid2が実行中なので待機状態になる
|
394
|
+
pid = @mng.restart_test( pid )["id"]
|
395
|
+
sleep 1
|
396
|
+
process = @mng.get( pid )
|
397
|
+
assert_equals process["state"], :WAITING
|
398
|
+
assert_not_nil process.progress
|
399
|
+
assert_equals process.process_id, pid
|
400
|
+
|
401
|
+
|
402
|
+
#pid2の完了待つ。完了後pid1が起動する。
|
403
|
+
sleep 1 while @mng.get( pid2 )["state"] == :RUNNING
|
404
|
+
|
405
|
+
process = @mng.get( pid2 )
|
406
|
+
assert_equals process["state"], :FINISHED
|
407
|
+
assert_not_nil process.progress
|
408
|
+
sleep 1
|
409
|
+
process = @mng.get( pid )
|
410
|
+
assert_equals process["state"], :RUNNING
|
411
|
+
assert_not_nil process.progress
|
412
|
+
|
413
|
+
|
414
|
+
# 別のプロセスを追加してpid1を削除
|
415
|
+
pid3 = @mng.create_back_test( "test3", "memo", Time.gm( 2008, 8, 21 ).to_i, Time.gm( 2008, 8, 22 ).to_i, agents )["id"]
|
416
|
+
sleep 1
|
417
|
+
process = @mng.get( pid3 )
|
418
|
+
assert_equals process["state"], :WAITING
|
419
|
+
assert_not_nil process.progress
|
420
|
+
|
421
|
+
@mng.delete_back_test( pid )
|
422
|
+
assert_process_not_found(pid)
|
423
|
+
|
424
|
+
sleep 1
|
425
|
+
process = @mng.get( pid3 )
|
426
|
+
assert_equals process["state"], :RUNNING
|
427
|
+
assert_not_nil process.progress
|
428
|
+
|
429
|
+
#追加したプロセスも削除
|
430
|
+
@mng.delete_back_test( pid3 )
|
431
|
+
assert_process_not_found(pid3)
|
432
|
+
|
433
|
+
end
|
434
|
+
|
435
|
+
# プロセスの属性変更のテスト。
|
436
|
+
def test_set
|
437
|
+
agents = [{
|
438
|
+
"name" => "aaa",
|
439
|
+
"class" => "MovingAverageAgent@moving_average.rb",
|
440
|
+
"id"=> "44c0d256-8994-4240-a6c6-8d9546aef8c4",
|
441
|
+
"properties" => {
|
442
|
+
"period" => 10,
|
443
|
+
"short" => 25,
|
444
|
+
"long" => 75
|
445
|
+
}
|
446
|
+
}]
|
447
|
+
|
448
|
+
@mng.start
|
449
|
+
@mng.set("rmt", { "agents"=>agents, "trade_enable"=>false })
|
450
|
+
pid1 = @mng.create_back_test( "test", "memo",
|
451
|
+
Time.gm( 2008, 8, 21 ).to_i, Time.gm( 2008, 8, 22 ).to_i, agents )["id"]
|
452
|
+
sleep 0.1
|
453
|
+
|
454
|
+
["rmt",pid1].each{|pid|
|
455
|
+
|
456
|
+
#初期状態の確認
|
457
|
+
process = @mng.get( pid )
|
458
|
+
assert_equals( process["agents"], agents )
|
459
|
+
assert_equals( process["trade_enable"], false )
|
460
|
+
assert_equals( @omng.get(pid, agents[0]["id"]).agent_name, "aaa" )
|
461
|
+
|
462
|
+
#エージェントの追加
|
463
|
+
agents2 = agents.map {|i| i.clone }
|
464
|
+
agents2 << {
|
465
|
+
"name" => "bbb",
|
466
|
+
"class" => "MovingAverageAgent@moving_average.rb",
|
467
|
+
"id"=> "54c0d256-8994-4240-a6c6-8d9546aef8c4",
|
468
|
+
"properties" => {
|
469
|
+
"period" => 10,
|
470
|
+
"short" => 25,
|
471
|
+
"long" => 75
|
472
|
+
}
|
473
|
+
}
|
474
|
+
@mng.set( pid, { "agents" => agents2 } )
|
475
|
+
process = @mng.get( pid )
|
476
|
+
assert_equals( process["agents"], agents2 )
|
477
|
+
assert_equals( process["trade_enable"], false )
|
478
|
+
assert_equals( @omng.get(pid, agents2[0]["id"]).agent_name, "aaa" )
|
479
|
+
assert_equals( @omng.get(pid, agents2[1]["id"]).agent_name, "bbb" )
|
480
|
+
|
481
|
+
|
482
|
+
#エージェントの名前変更
|
483
|
+
agents2[0]["name"] = "aaa2"
|
484
|
+
@mng.set( pid, { "agents" => agents2 } )
|
485
|
+
process = @mng.get( pid )
|
486
|
+
assert_equals( process["agents"], agents2 )
|
487
|
+
assert_equals( process["trade_enable"], false )
|
488
|
+
assert_equals( @omng.get(pid, agents2[0]["id"]).agent_name, "aaa2" )
|
489
|
+
assert_equals( @omng.get(pid, agents2[1]["id"]).agent_name, "bbb" )
|
490
|
+
|
491
|
+
|
492
|
+
#エージェントのプロパティ変更
|
493
|
+
agents2[0]["properties"] = {
|
494
|
+
"period" => 20,
|
495
|
+
"short" => 25,
|
496
|
+
"long" => 75
|
497
|
+
}
|
498
|
+
@mng.set( pid, { "agents" => agents2 } )
|
499
|
+
process = @mng.get( pid )
|
500
|
+
assert_equals( process["agents"], agents2 )
|
501
|
+
assert_equals( process["trade_enable"], false )
|
502
|
+
assert_equals( @omng.get(pid, agents2[0]["id"]).agent_name, "aaa2" )
|
503
|
+
assert_equals( @omng.get(pid, agents2[1]["id"]).agent_name, "bbb" )
|
504
|
+
|
505
|
+
#tradeのon/off
|
506
|
+
if ( pid == "rmt" )
|
507
|
+
@mng.set( pid, { "trade_enable" => "true" } )
|
508
|
+
process = @mng.get( pid )
|
509
|
+
assert_equals( process["agents"], agents2 )
|
510
|
+
assert_equals( process["trade_enable"], true )
|
511
|
+
assert_equals( @omng.get(pid, agents2[0]["id"]).agent_name, "aaa2" )
|
512
|
+
assert_equals( @omng.get(pid, agents2[1]["id"]).agent_name, "bbb" )
|
513
|
+
|
514
|
+
@mng.set( pid, { "trade_enable" => "false" } )
|
515
|
+
process = @mng.get( pid )
|
516
|
+
assert_equals( process["trade_enable"], false )
|
517
|
+
|
518
|
+
@mng.set( pid, { "trade_enable" => true } )
|
519
|
+
process = @mng.get( pid )
|
520
|
+
assert_equals( process["trade_enable"], true )
|
521
|
+
|
522
|
+
@mng.set( pid, { "trade_enable" => false } )
|
523
|
+
process = @mng.get( pid )
|
524
|
+
assert_equals( process["trade_enable"], false )
|
525
|
+
else
|
526
|
+
# バックテストではtrueにできない
|
527
|
+
begin
|
528
|
+
@mng.set( pid, { "trade_enable" => "true" } )
|
529
|
+
fail
|
530
|
+
rescue JIJI::UserError
|
531
|
+
end
|
532
|
+
process = @mng.get( pid )
|
533
|
+
assert_equals( process["agents"], agents2 )
|
534
|
+
assert_equals( process["trade_enable"], false )
|
535
|
+
assert_equals( @omng.get(pid, agents2[0]["id"]).agent_name, "aaa2" )
|
536
|
+
assert_equals( @omng.get(pid, agents2[1]["id"]).agent_name, "bbb" )
|
537
|
+
end
|
538
|
+
|
539
|
+
#エージェントの削除
|
540
|
+
agents3 = agents2[0..1]
|
541
|
+
@mng.set( pid, { "agents" => agents3 } )
|
542
|
+
process = @mng.get( pid )
|
543
|
+
assert_equals( process["agents"], agents3 )
|
544
|
+
assert_equals( process["trade_enable"], false )
|
545
|
+
assert_equals( @omng.get(pid, agents2[0]["id"]).agent_name, "aaa2" )
|
546
|
+
assert_equals( @omng.get(pid, agents2[1]["id"]).agent_name, "bbb" )
|
547
|
+
|
548
|
+
}
|
549
|
+
@mng.delete_back_test( pid1 )
|
550
|
+
end
|
551
|
+
|
552
|
+
# 属性変更の異常系テスト。
|
553
|
+
def test_set_error
|
554
|
+
|
555
|
+
agents = []
|
556
|
+
@mng.start
|
557
|
+
pid1 = @mng.create_back_test( "test", "memo",
|
558
|
+
Time.gm( 2008, 8, 21 ).to_i, Time.gm( 2008, 8, 22 ).to_i, agents )["id"]
|
559
|
+
sleep 0.1
|
560
|
+
|
561
|
+
error_registry = Test::RegistryMock.new
|
562
|
+
@mng.rmt.agent_manager.agent_registry = error_registry
|
563
|
+
@mng.executor.get( pid1 ).agent_manager.agent_registry = error_registry
|
564
|
+
|
565
|
+
agents_org = [{
|
566
|
+
"name" => "aaa",
|
567
|
+
"class" => "Test@foo.rb",
|
568
|
+
"id"=> "a",
|
569
|
+
"properties" => {
|
570
|
+
"period" => 10,
|
571
|
+
"short" => 25,
|
572
|
+
"long" => 75
|
573
|
+
}
|
574
|
+
}]
|
575
|
+
@mng.set("rmt", { "agents"=>agents_org, "trade_enable"=>false })
|
576
|
+
@mng.set(pid1, { "agents"=>agents_org })
|
577
|
+
|
578
|
+
["rmt",pid1].each{|pid|
|
579
|
+
agents = agents_org.map{|i| i.clone }
|
580
|
+
|
581
|
+
#追加でエラー
|
582
|
+
Test::RegistryMock.set_fail_create {|cl,p| cl == "Test3@foo.rb" }
|
583
|
+
agents2 = agents.map{|i| i.clone }
|
584
|
+
agents2 << {
|
585
|
+
"name" => "bbb",
|
586
|
+
"class" => "Test2@foo.rb",
|
587
|
+
"id"=> "b",
|
588
|
+
"properties" => {
|
589
|
+
"period" => 10,
|
590
|
+
"short" => 25,
|
591
|
+
"long" => 75
|
592
|
+
}
|
593
|
+
}
|
594
|
+
agents2 << {
|
595
|
+
"name" => "ccc",
|
596
|
+
"class" => "Test3@foo.rb",
|
597
|
+
"id"=> "c",
|
598
|
+
"properties" => {
|
599
|
+
"period" => 10,
|
600
|
+
"short" => 25,
|
601
|
+
"long" => 75
|
602
|
+
}
|
603
|
+
}
|
604
|
+
result = @mng.set( pid, { "agents" => agents2 } )
|
605
|
+
assert_not_nil result["c"][:cause]
|
606
|
+
assert_equals result["c"][:info], agents2[2]
|
607
|
+
assert_equals result["c"][:operation], :add
|
608
|
+
assert_nil result["a"]
|
609
|
+
assert_nil result["b"]
|
610
|
+
|
611
|
+
agents = agents2[0..1]
|
612
|
+
process = @mng.get( pid )
|
613
|
+
assert_equals( process["agents"], agents )
|
614
|
+
assert_equals( process["trade_enable"], false )
|
615
|
+
assert_equals( @omng.get(pid, "a").agent_name, "aaa" )
|
616
|
+
assert_equals( @omng.get(pid, "b").agent_name, "bbb" )
|
617
|
+
begin
|
618
|
+
@omng.get(pid, "c")
|
619
|
+
fail
|
620
|
+
rescue JIJI::UserError
|
621
|
+
end
|
622
|
+
|
623
|
+
Test::RegistryMock.set_fail_create {|cl,p| false }
|
624
|
+
|
625
|
+
#更新でエラー
|
626
|
+
Test::Agent.set_fail_propset {|a| a.cl == "Test@foo.rb" }
|
627
|
+
agents2 = agents.map{|i| i.clone}
|
628
|
+
agents2[0]["name"] = "aaa2"
|
629
|
+
agents2[0]["properties"] = {
|
630
|
+
"period" => 20,
|
631
|
+
"short" => 100
|
632
|
+
}
|
633
|
+
agents2[1]["name"] = "bbb2"
|
634
|
+
agents2[1]["properties"] = {
|
635
|
+
"period" => 21,
|
636
|
+
"short" => 101
|
637
|
+
}
|
638
|
+
result = @mng.set( pid, { "agents" => agents2 } )
|
639
|
+
assert_not_nil result["a"][:cause]
|
640
|
+
assert_equals result["a"][:info], agents2[0]
|
641
|
+
assert_equals result["a"][:operation], :update
|
642
|
+
assert_nil result["b"]
|
643
|
+
|
644
|
+
agents = [agents[0],agents2[1]]
|
645
|
+
process = @mng.get( pid )
|
646
|
+
assert_equals( process["agents"], agents )
|
647
|
+
assert_equals( process["trade_enable"], false )
|
648
|
+
assert_equals( @omng.get(pid, "a").agent_name, "aaa" )
|
649
|
+
assert_equals( @omng.get(pid, "b").agent_name, "bbb2" )
|
650
|
+
Test::Agent.set_fail_propset {|a| false }
|
651
|
+
|
652
|
+
#削除でエラー
|
653
|
+
target = pid == "rmt" ? @mng.rmt.agent_manager : @mng.executor.get( pid ).agent_manager
|
654
|
+
class << target
|
655
|
+
def remove( agent_id )
|
656
|
+
raise "test" if agent_id == "a"
|
657
|
+
super
|
658
|
+
end
|
659
|
+
end
|
660
|
+
result = @mng.set( pid, { "agents" => []} )
|
661
|
+
assert_not_nil result["a"][:cause]
|
662
|
+
assert_equals result["a"][:info], agents[0]
|
663
|
+
assert_equals result["a"][:operation], :remove
|
664
|
+
assert_nil result["b"]
|
665
|
+
|
666
|
+
process = @mng.get( pid )
|
667
|
+
assert_equals( process["agents"], [agents[0]] )
|
668
|
+
assert_equals( process["trade_enable"], false )
|
669
|
+
assert_equals( @omng.get(pid, "a").agent_name, "aaa" )
|
670
|
+
assert_equals( @omng.get(pid, "b").agent_name, "bbb2" )
|
671
|
+
|
672
|
+
}
|
673
|
+
@mng.delete_back_test( pid1 )
|
674
|
+
end
|
675
|
+
|
676
|
+
# 異常系テスト。
|
677
|
+
def test_error
|
678
|
+
# RMT起動時にエージェント作成でエラー / ログ出力のみ行なわれ、処理は継続
|
679
|
+
@mng.start
|
680
|
+
agents = [{
|
681
|
+
"name" => "aaa",
|
682
|
+
"class" => "MovingAverageAgent@moving_average.rb",
|
683
|
+
"id"=> "a",
|
684
|
+
"properties" => {}
|
685
|
+
}]
|
686
|
+
@mng.set( "rmt", {"agents"=>agents});
|
687
|
+
process = @mng.get( "rmt" )
|
688
|
+
assert_equals( process["agents"], agents )
|
689
|
+
|
690
|
+
recreate_registry
|
691
|
+
@registry[:agent_registry].unload( "agents/moving_average.rb" )
|
692
|
+
@mng = @registry[:process_manager]
|
693
|
+
@mng.start # エラーが発生しない
|
694
|
+
process = @mng.get( "rmt" )
|
695
|
+
assert_equals( process["agents"], agents ) # 設定はそのまま保持されている
|
696
|
+
|
697
|
+
|
698
|
+
# バックテスト作成時にエージェント作成でエラー / 例外が返される。
|
699
|
+
begin
|
700
|
+
@mng.create_back_test( "test", "memo",
|
701
|
+
Time.gm( 2008, 8, 21 ).to_i, Time.gm( 2008, 8, 22 ).to_i, agents )
|
702
|
+
fail
|
703
|
+
rescue JIJI::UserError
|
704
|
+
end
|
705
|
+
end
|
706
|
+
|
707
|
+
def recreate_registry
|
708
|
+
Test.destry( @registry )
|
709
|
+
FileUtils.rm_rf "#{@dir}/logs"
|
710
|
+
return @registry = JIJI::Registry.new(@dir , nil)
|
711
|
+
end
|
712
|
+
|
713
|
+
# プロセスが存在しないことを確認する。
|
714
|
+
def assert_process_not_found( pid )
|
715
|
+
begin
|
716
|
+
@mng.get( pid )
|
717
|
+
fail
|
718
|
+
rescue JIJI::UserError
|
719
|
+
assert_equals JIJI::ERROR_NOT_FOUND, $!.code
|
720
|
+
end
|
721
|
+
end
|
722
|
+
|
723
|
+
end
|