<?xml version="1.0" encoding="UTF-8"?>
<ccxml xmlns="http://www.w3.org/2002/09/ccxml" xmlns:conf="http://www.w3.org/2005/ccxml-conformance" version="1.0">
<!--
Serguei's infrastructure performs a loop on the 'assertions' Ecma array, based on "name_prepare_new" event for doing the "loop".

Mainly we have to different levels of assertions: 

- Main assertions, stored in 'assertions' array
- Children assertions, stored into 'assert_trace'

An assertion is a child assertion if it does not need to perform any action, but it is sufficient to test its father assertion result to determine if it passes or fails.

The test finishes when all the main assertions have been tested. Children assertions are tested after the father itself.

If an unexpected event is caught by the <transition event"*"/> a comment is printed and the loop continues with the next iteration.

An hang up event causes the interruption of test: session exits.

All the send.successful events are caught and ignored (they are generated by the loop mechanism).
-->


<!--
Release 1.1 - 2010-06-09
FIXED: 
ISSUE-701, TA 889. 
-->

<!-- IMPORTANT: To successfully run this test you must tear down the VoiceXML engine immediately after the dialog has been started -->

	<conf:docsetup/>

	<var name="DialogID" expr="undefined"/>
	<var name="ConnectionID" expr="undefined"/>
	<var name="ConferenceID" expr="undefined"/>
	<var name="bIsOK" expr="false"/>
	
	<var name="vxmlFile" expr="'7_6.vxml'"/>
	<var name="myConfName" expr="'SimpleConference'"/>

	<var name="chld_reason"/>

	<script><![CDATA[
		var i=0;
		// ==========================
		// error.dialog tests  on conference
		assertions[i++] = init_assertion('889');				
				
		var assert_last = i - 1;
		var assert_index = -1;
		//
		// out of the loop assertions (children)
		
		// Child of 889 on error.dialog on conference
		add_2_assert_trace('890');	
		
		s_ASSERTIONS_LEFT = show_remained_assertions();
		var b_in_test = false;
	]]></script>
	
	<eventprocessor statevariable="current_state">
				<conf:setup type="connected"/>
    
		<transition event="connection.connected" state="init">
			<assign name="ConnectionID" expr="event$.connectionid"/>
			<send targettype="'ccxml'" target="session.id" name="'user.timeout'" delay="TEST_LONG_TIMEOUT"/>
			<send targettype="'ccxml'" target="session.id" name="name_prepare_new"/>
		</transition>

		<transition event="user.PREPARE_NEW">
			<conf:comment expr="'Event: ' + event$.name"/>
			<if cond="assert_index &gt;= 0">
				<assign name="ASSERTION_NUM" expr="assertions[assert_index].number"/>
				<assign name="t_ASSERT_RESULT" expr="assertions[assert_index].P_F"/>
				<script>assertions[assert_index].reason = t_ASSERT_REASON;</script>
				<if cond="t_ASSERT_RESULT == s_PASS">
					<conf:pass reason="t_ASSERT_REASON"/>
					<elseif cond="t_ASSERT_RESULT == s_FAIL"/>
					<conf:fail reason="t_ASSERT_REASON"/>
					<else/>
					<conf:not_exec reason="t_ASSERT_REASON"/>
				</if>
			</if>
			<assign name="assert_index" expr="assert_index + 1"/>
			<if cond="assert_index &gt; assert_last">
				<log label="s_TA" expr="s_ASSERTIONS_LEFT"/>
				<conf:uncond_exit expr="'DONE'"/>
				<else/>
				<log label="s_TA" expr="s_ASSERTIONS_LEFT"/>
				<assign name="ASSERTION_NUM" expr=" assertions[assert_index].number"/>
				<assign name="t_ASSERT_REASON" expr="''"/>
				<script>assertions[assert_index].P_F = s_FAIL;</script>
				<assign name="current_state" expr="state_prefix + ASSERTION_NUM"/>
				<send targettype="'ccxml'" target="session.id" name="start_name_prefix + ASSERTION_NUM"/>
			</if>
		</transition>

		
		<!-- Starting test on error.dialog-->		
		<!-- TA 889:  error.dialog on conference -->
		<transition event="user.START_ASSERTION_889" state="ASSERTION_NMBR_889">
			<conf:comment expr=" 'Current state : ' + current_state + ' , Event: ' + event$.name"/>
			<createconference confname="myConfName" conferenceid="ConferenceID"/>
		</transition>
		<transition event="conference.created" state="ASSERTION_NMBR_889">
			<conf:comment expr=" 'Current state : ' + current_state + ' , Event: ' + event$.name"/>
			<dialogstart src="vxmlFile" dialogid="DialogID" conferenceid="ConferenceID"/>				
		</transition>
		
		<transition event="dialog.started" state="ASSERTION_NMBR_889">
			<conf:comment expr=" 'Current state : ' + current_state + ' , Event: ' + event$.name"/>
		</transition>

		<transition event="error.dialog" state="ASSERTION_NMBR_889">
			<conf:comment expr=" 'Current state : ' + current_state + ' , Event: ' + event$.name"/>
			<if cond="event$.connectionid == undefined">	
				<script>assertions[assert_index].P_F = s_PASS;</script>
			<else/>
				<assign name="t_ASSERT_REASON" expr="'Incorrect value for connectionid on error.dialog event: it MUST be undefined !' "/>
				<script>
					assertions[assert_index].P_F = s_FAIL;
					assertions[assert_index].reason = t_ASSERT_REASON;  
				</script>
			</if>			
			<assign name="ASSERTION_NUM" expr="'890'"/>
			<if cond="event$.conferenceid == ConferenceID">
				<conf:pass/>
			<else/>
				<conf:fail reason="'Incorrect conferenceid on error.dialog event !'"/>
			</if>
			<destroyconference conferenceid="ConferenceID"/>		
		</transition>
		
		<!-- FIXED ISSUE-701:  conference.unjoined added -->
		<transition event="conference.unjoined">
			<conf:comment expr="'Event: ' + event$.name"/>
		</transition>	
		
		<!-- <destroyconference conferenceid="ConferenceID"/>-->
		<transition event="conference.destroyed" state="ASSERTION_NMBR_889">
			<conf:comment expr=" 'Current state : ' + current_state + ' , Event: ' + event$.name"/>
			<send targettype="'ccxml'" target="session.id" name="name_prepare_new"/>
		</transition>

		<!-- Safety timeout -->					
		 <transition event="user.timeout">
			<assign name="current_state" expr="'GEN'"/>
			<conf:uncond_exit expr="'TEST-TIMEOUT.' + show_remained_assertions()"/>
        </transition>
		
		<transition event="send.successful">
		</transition>
		
		<transition event="connection.disconnected">
			<conf:uncond_exit expr="'CONNECTION-DISCONNECTED'"/>
		</transition>
	
		<transition event="*">
			<assign name="t_ASSERT_REASON" expr="'UNEXPECTED EVENT ' + event$.name + ' IN STATE ' + current_state"/>
				<conf:comment expr="t_ASSERT_REASON"/>
				<if cond="current_state == 'init'">
					<conf:uncond_exit expr="'Did not come out from init state.'"/>
				<else/>
					<send targettype="'ccxml'" target="session.id" name="name_prepare_new"/>
				</if>   
			</transition>
	
		</eventprocessor>
</ccxml>
