# # Testing OpenWFE # # John Mettraux at openwfe.org # # Sun Oct 29 15:41:44 JST 2006 # # Kita Yokohama # require 'test/unit' #require 'openwfe/workitem' require 'openwfe/flowexpressionid' require 'openwfe/engine/engine' require 'openwfe/expressions/raw_prog' require 'openwfe/worklist/storeparticipant' include OpenWFE class HParticipantTest < Test::Unit::TestCase def setup @engine = Engine.new() end #def teardown #end class HpDefinition0 < ProcessDefinition def make process_definition :name => "hp0", :revision => "0" do sequence do participant :alice participant :bob end end end end def test_hp_0 @hpAlice = HashParticipant.new @hpBob = HashParticipant.new @engine.register_participant(:alice, @hpAlice) @engine.register_participant(:bob, @hpBob) do_test() end def test_hp_1 FileUtils.remove_dir "./work" if File.exist? "./work" @engine.application_context[:work_directory] = "./work" @hpAlice = YamlParticipant.new("alice", @engine.application_context) #@hpBob = YamlParticipant.new("bob", @engine.application_context) @engine.register_participant(:alice, @hpAlice) #@engine.register_participant(:bob, @hpBob) @hpBob = @engine.register_participant(:bob, YamlParticipant) do_test() end def do_test id = @engine.launch(HpDefinition0) assert \ (id.kind_of? FlowExpressionId), "engine.launch() doesn't return an instance of FlowExpressionId "+ "but of #{id.class}" #puts id.to_s #puts "alice count : #{@hpAlice.size}" #puts "bob count : #{@hpBob.size}" assert \ @hpBob.size == 0 assert \ @hpAlice.size == 1 wi = @hpAlice.list_workitems(id.workflow_instance_id)[0] assert \ wi != nil, "didn't find wi for flow #{id.workflow_instance_id}" wi.message = "Hello bob !" @hpAlice.forward(wi) assert \ @hpAlice.size == 0 assert \ @hpBob.size == 1 wi = @hpBob.list_workitems(id.workflow_instance_id)[0] assert \ wi.message == "Hello bob !" @hpBob.proceed(wi) assert \ @hpAlice.size == 0 assert \ @hpBob.size == 0 assert \ @engine.get_expression_storage.size == 1 end end