Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(238)

Side by Side Diff: gin/modules/timer_unittest.cc

Issue 120043008: Add a simple one shot and repeating timer API for Mojo.js. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "gin/modules/timer.h"
6
7 #include "base/message_loop/message_loop.h"
8 #include "gin/handle.h"
9 #include "gin/object_template_builder.h"
10 #include "gin/public/isolate_holder.h"
11 #include "gin/runner.h"
12 #include "gin/test/v8_test.h"
13 #include "gin/try_catch.h"
14 #include "gin/wrappable.h"
15 #include "v8/include/v8.h"
16
17 namespace gin {
18
19 namespace {
20
21 class Result : public Wrappable<Result> {
22 public:
23 static WrapperInfo kWrapperInfo;
24 static Handle<Result> Create(v8::Isolate* isolate) {
25 return CreateHandle(isolate, new Result());
26 }
27
28 int count() const { LOG(ERROR) << "returning " << count_; return count_; }
29 void set_count(int count) { count_ = count; }
30
31 void print(const std::string& val) {
32 LOG(ERROR) << val;
33 }
34
35 void quit() {
36 base::MessageLoop::current()->Quit();
37 }
38
39 private:
40 Result() : count_(0) {
41 }
42
43 virtual ~Result() {
44 }
45
46 virtual ObjectTemplateBuilder GetObjectTemplateBuilder(
47 v8::Isolate* isolate) OVERRIDE {
48 return Wrappable<Result>::GetObjectTemplateBuilder(isolate)
49 .SetProperty("count", &Result::count, &Result::set_count)
50 .SetMethod("quit", &Result::quit)
51 .SetMethod("print", &Result::print);
52 }
53
54 int count_;
55 };
56
57 WrapperInfo Result::kWrapperInfo = { gin::kEmbedderNativeGin };
58
59 } // namespace
60
61 typedef V8Test TimerUnittest;
62
63 TEST_F(TimerUnittest, OneShot) {
64 v8::Isolate* isolate = instance_->isolate();
65
66 RunnerDelegate delegate;
67 Runner runner(&delegate, isolate);
68 Runner::Scope scope(&runner);
69
70 Handle<TimerModule> timer_module = TimerModule::Create(isolate);
71 Handle<Result> result = Result::Create(isolate);
72
73 EXPECT_FALSE(runner.global().IsEmpty());
74 runner.global()->Set(StringToV8(isolate, "timer"),
75 timer_module->GetWrapper(isolate));
76 runner.global()->Set(StringToV8(isolate, "result"),
77 result->GetWrapper(isolate));
78
79 std::string source =
80 "timer.createOneShot(100, function() {"
81 " result.count++;"
82 " result.quit();"
83 "});";
84
85 base::MessageLoop loop(base::MessageLoop::TYPE_DEFAULT);
86 runner.Run(source, "script");
87 EXPECT_EQ(0, result->count());
88
89 loop.Run();
90 loop.RunUntilIdle();
91
92 EXPECT_EQ(1, result->count());
93 }
94
95 TEST_F(TimerUnittest, Repeating) {
96 v8::Isolate* isolate = instance_->isolate();
97
98 RunnerDelegate delegate;
99 Runner runner(&delegate, isolate);
100 Runner::Scope scope(&runner);
101
102 Handle<TimerModule> timer_module = TimerModule::Create(isolate);
103 Handle<Result> result = Result::Create(isolate);
104
105 EXPECT_FALSE(runner.global().IsEmpty());
106 runner.global()->Set(StringToV8(isolate, "timer"),
107 timer_module->GetWrapper(isolate));
108 runner.global()->Set(StringToV8(isolate, "result"),
109 result->GetWrapper(isolate));
110
111 // TODO(aa): Cannot do: if (++result.count == 3) because of v8 bug. Create
112 // test case and report.
113 std::string source =
114 "timer.createRepeating(10, function() {"
115 " result.count++;"
116 " if (result.count == 3) {"
117 " result.quit();"
118 " }"
119 "});";
120
121 base::MessageLoop loop(base::MessageLoop::TYPE_DEFAULT);
122 runner.Run(source, "script");
123 EXPECT_EQ(0, result->count());
124
125 loop.Run();
126 EXPECT_EQ(3, result->count());
127 }
128
129 } // namespace gin
OLDNEW
« no previous file with comments | « gin/modules/timer.cc ('k') | gin/runner.cc » ('j') | gin/runner.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698