use ObjectURI more consistently
[gnash.git] / testsuite / misc-ming.all / intervalTestRunner.cpp
blobd296c2a48e4259669a1e2e1fec4dec4dadfd2f2d
1 /*
2 * Copyright (C) 2007, 2008, 2009, 2010 Free Software Foundation, Inc.
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 3 of the License, or
7 * (at your option) any later version.
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
19 */
21 #define INPUT_FILENAME "intervalTest.swf"
23 #include "MovieTester.h"
24 #include "MovieClip.h"
25 #include "DisplayObject.h"
26 #include "DisplayList.h"
27 #include "log.h"
28 #include "VM.h"
30 #include "check.h"
31 #include <string>
32 #include <cassert>
33 #include "GnashSystemIOHeaders.h"
35 using namespace gnash;
36 using namespace std;
38 int
39 main(int /*argc*/, char** /*argv*/)
41 string filename = string(TGTDIR) + string("/") + string(INPUT_FILENAME);
42 MovieTester tester(filename);
44 gnash::LogFile& dbglogfile = gnash::LogFile::getDefaultInstance();
45 dbglogfile.setVerbosity(1);
47 as_value tmp;
49 MovieClip* root = tester.getRootMovie();
50 assert(root);
52 check_equals(root->get_frame_count(), 2);
53 check_equals(root->get_current_frame(), 0);
54 check_equals(root->getPlayState(), MovieClip::PLAYSTATE_PLAY);
56 tester.advanceClock(50); // "sleep" 50 milliseconds
57 tester.advance(); // execute actions in second frame frame
59 check_equals(root->get_current_frame(), 1);
60 check_equals(root->getPlayState(), MovieClip::PLAYSTATE_STOP);
62 // Now timers are set and counters initialized
64 VM& vm = tester.vm();
65 const ObjectURI& thisCounter = getURI(vm, "this_counter");
66 const ObjectURI& thatCounter = getURI(vm, "that_counter");
67 const ObjectURI& pushedArgs = getURI(vm, "pushed_args");
68 const ObjectURI& testCompleted = getURI(vm, "test_completed");
70 getObject(root)->get_member(thisCounter, &tmp);
71 check_equals(toNumber(tmp, vm), 0);
72 getObject(root)->get_member(thatCounter, &tmp);
73 check_equals(toNumber(tmp, vm), 0);
75 tester.advanceClock(500); // "sleep" 500 milliseconds
76 tester.advance(); // run expired timers
78 getObject(root)->get_member(thisCounter, &tmp);
79 check_equals(toNumber(tmp, vm), 1);
80 getObject(root)->get_member(thatCounter, &tmp);
81 check_equals(toNumber(tmp, vm), 0);
83 tester.advanceClock(600); // "sleep" 500 milliseconds
84 tester.advance(); // run expired timers
86 getObject(root)->get_member(thisCounter, &tmp);
87 check_equals(toNumber(tmp, vm), 2);
88 getObject(root)->get_member(thatCounter, &tmp);
89 check_equals(toNumber(tmp, vm), 1);
91 tester.advanceClock(500); // "sleep" 500 milliseconds
92 tester.advance(); // run expired timers
94 getObject(root)->get_member(thisCounter, &tmp);
95 check_equals(toNumber(tmp, vm), 3);
96 getObject(root)->get_member(thatCounter, &tmp);
97 check_equals(toNumber(tmp, vm), 1);
99 tester.advanceClock(520); // "sleep" 520 milliseconds
100 tester.advance(); // run expired timers
102 getObject(root)->get_member(thisCounter, &tmp);
103 check_equals(toNumber(tmp, vm), 4);
104 getObject(root)->get_member(thatCounter, &tmp);
105 check_equals(toNumber(tmp, vm), 2);
107 tester.advanceClock(1020); // "sleep" 1020 milliseconds
108 tester.advance(); // run expired timers
110 getObject(root)->get_member(thisCounter, &tmp);
111 check_equals(toNumber(tmp, vm), 4);
112 getObject(root)->get_member(thatCounter, &tmp);
113 check_equals(toNumber(tmp, vm), 3);
115 tester.advanceClock(1020); // "sleep" 1020 milliseconds
116 tester.advance(); // run expired timers
118 getObject(root)->get_member(thisCounter, &tmp);
119 check_equals(toNumber(tmp, vm), 4);
120 getObject(root)->get_member(thatCounter, &tmp);
121 check_equals(toNumber(tmp, vm), 4);
123 tester.advanceClock(520); // "sleep" 520 milliseconds
124 tester.advance(); // run expired timers
126 getObject(root)->get_member(thisCounter, &tmp);
127 check_equals(toNumber(tmp, vm), 5);
128 getObject(root)->get_member(thatCounter, &tmp);
129 check_equals(toNumber(tmp, vm), 4);
131 getObject(root)->get_member(pushedArgs, &tmp);
132 as_environment env(vm); // needed for proper to_string()
133 check_equals(tmp.to_string(), std::string("8,9,10"));
135 tester.advanceClock(100); // "sleep" another 100 milliseconds
136 tester.advance(); // run expired timers
138 getObject(root)->get_member(testCompleted, &tmp);
139 check_equals(toNumber(tmp, vm), 1);