1 // Copyright 2015 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.
10 * @param {number} width
11 * @param {number} height
12 * @return {{width:number, height:number}}
14 function size(width
, height
) {
15 return {width
: width
, height
: height
};
21 * @return {{x:number, y:number}}
27 QUnit
.module('Viewport');
29 QUnit
.test('choosePluginSize() handles low-DPI client & host',
31 // 1. Client & host size the same.
32 var pluginSize
= remoting
.Viewport
.choosePluginSize(
33 size(640, 480), 1.0, size(640, 480), dpi(96, 96), 1.0, false, true);
34 assert
.deepEqual(pluginSize
, size(640, 480));
36 // 2. Client logical dimensions smaller than host's.
37 pluginSize
= remoting
.Viewport
.choosePluginSize(
38 size(640, 480), 1.0, size(1024, 600), dpi(96, 96), 1.0, false, true);
39 assert
.deepEqual(pluginSize
, size(640, (640 / 1024) * 600));
41 // 3. Client Y dimension larger than host's, X dimension smaller.
42 pluginSize
= remoting
.Viewport
.choosePluginSize(
43 size(640, 640), 1.0, size(1024, 600), dpi(96, 96), 1.0, false, true);
44 assert
.deepEqual(pluginSize
, size(640, (640 / 1024) * 600));
46 // 4. Client dimensions larger than host's by <2x.
47 pluginSize
= remoting
.Viewport
.choosePluginSize(
48 size(1280, 900), 1.0, size(640, 480), dpi(96, 96), 1.0, false, true);
49 assert
.deepEqual(pluginSize
, size(640, 480));
51 // 5. Client dimensions larger than host's by >2x.
52 pluginSize
= remoting
.Viewport
.choosePluginSize(
53 size(1280, 1024), 1.0, size(640, 480), dpi(96, 96), 1.0, false, true);
54 assert
.deepEqual(pluginSize
, size(2 * 640, 2 * 480));
56 // 6. Client X dimension larger than host's, Y dimension smaller.
57 pluginSize
= remoting
.Viewport
.choosePluginSize(
58 size(1152, 600), 1.0, size(1024, 768), dpi(96, 96), 1.0, false, true);
59 assert
.deepEqual(pluginSize
, size(1024 * (600 / 768), 600));
62 QUnit
.test('choosePluginSize() handles high-DPI client, low-DPI host',
64 // 1. Client & host size the same.
65 var pluginSize
= remoting
.Viewport
.choosePluginSize(
66 size(640, 480), 2.0, size(640, 480), dpi(96, 96), 1.0, false, true);
67 assert
.deepEqual(pluginSize
, size(640, 480));
69 // 2. Client logical dimensions smaller than host's.
70 pluginSize
= remoting
.Viewport
.choosePluginSize(
71 size(640, 480), 2.0, size(1024, 600), dpi(96, 96), 1.0, false, true);
72 assert
.deepEqual(pluginSize
, size(640, (640 / 1024) * 600));
74 // 3. Client Y dimension larger than host's, X dimension smaller.
75 pluginSize
= remoting
.Viewport
.choosePluginSize(
76 size(640, 640), 2.0, size(1024, 600), dpi(96, 96), 1.0, false, true);
77 assert
.deepEqual(pluginSize
, size(640, (640 / 1024) * 600));
79 // 4. Client logical dimensions larger than host's by <2x.
80 // Host dimensions fit into the client's _device_ dimensions 3x, so the
81 // size in client DIPs should be 1:3/2.
82 pluginSize
= remoting
.Viewport
.choosePluginSize(
83 size(1280, 900), 2.0, size(640, 480), dpi(96, 96), 1.0, false, true);
84 assert
.deepEqual(pluginSize
, size(640 * 3 / 2.0, 480 * 3 / 2.0));
86 // 5. Client dimensions larger than host's by >2x.
87 pluginSize
= remoting
.Viewport
.choosePluginSize(
88 size(1280, 1024), 2.0, size(640, 480), dpi(96, 96), 1.0, false, true);
89 assert
.deepEqual(pluginSize
, size(1280, (1280 / 640) * 480));
91 // 6. Client X dimension larger than host's, Y dimension smaller.
92 pluginSize
= remoting
.Viewport
.choosePluginSize(
93 size(1152, 600), 2.0, size(1024, 768), dpi(96, 96), 1.0, false, true);
94 assert
.deepEqual(pluginSize
, size(1024 * (600 / 768), 600));
97 QUnit
.test('choosePluginSize() handles low-DPI client, high-DPI host',
99 // 1. Client & host size the same.
100 var pluginSize
= remoting
.Viewport
.choosePluginSize(
101 size(640, 480), 1.0, size(640, 480), dpi(192, 192), 1.0, false, true);
102 assert
.deepEqual(pluginSize
, size(640, 480));
104 // 2. Client logical dimensions smaller than host's.
105 pluginSize
= remoting
.Viewport
.choosePluginSize(
106 size(640, 480), 1.0, size(1024, 600), dpi(192, 192), 1.0, false, true);
107 assert
.deepEqual(pluginSize
, size(640, (640 / 1024) * 600));
109 // 3. Client Y dimension larger than host's, X dimension smaller.
110 pluginSize
= remoting
.Viewport
.choosePluginSize(
111 size(640, 640), 1.0, size(1024, 600), dpi(192, 192), 1.0, false, true);
112 assert
.deepEqual(pluginSize
, size(640, (640 / 1024) * 600));
114 // 4. Client dimensions larger than host's by <2x.
115 pluginSize
= remoting
.Viewport
.choosePluginSize(
116 size(1280, 900), 1.0, size(640, 480), dpi(192, 192), 1.0, false, true);
117 assert
.deepEqual(pluginSize
, size(640, 480));
119 // 5. Client dimensions larger than host's by >2x.
120 pluginSize
= remoting
.Viewport
.choosePluginSize(
121 size(1280, 1024), 1.0, size(640, 480), dpi(192, 192), 1.0, false, true);
122 assert
.deepEqual(pluginSize
, size(1280, (1280 / 640) * 480));
124 // 6. Client X dimension larger than host's, Y dimension smaller.
125 pluginSize
= remoting
.Viewport
.choosePluginSize(
126 size(1152, 600), 1.0, size(1024, 768), dpi(192, 192), 1.0, false, true);
127 assert
.deepEqual(pluginSize
, size(1024 * (600 / 768), 600));
130 QUnit
.test('choosePluginSize() handles high-DPI client and host',
132 // 1. Client & host size the same.
133 var pluginSize
= remoting
.Viewport
.choosePluginSize(
134 size(640, 480), 2.0, size(640, 480), dpi(192, 192), 1.0, false, true);
135 assert
.deepEqual(pluginSize
, size(640, 480));
137 // 2. Client logical dimensions smaller than host's.
138 pluginSize
= remoting
.Viewport
.choosePluginSize(
139 size(640, 480), 2.0, size(1024, 600), dpi(192, 192), 1.0, false, true);
140 assert
.deepEqual(pluginSize
, size(1024 / 2.0, 600 / 2.0));
142 // 3. Client Y dimension larger than host's, X dimension smaller.
143 pluginSize
= remoting
.Viewport
.choosePluginSize(
144 size(640, 640), 2.0, size(1024, 600), dpi(192, 192), 1.0, false, true);
145 assert
.deepEqual(pluginSize
, size(1024 / 2.0, 600 / 2.0));
147 // 4. Client logical dimensions larger than host's by <2x.
148 // Host dimensions fit into the client's _device_ dimensions 3x, so the
149 // size in client DIPs should be 1:3/2.
150 pluginSize
= remoting
.Viewport
.choosePluginSize(
151 size(1280, 900), 2.0, size(640, 480), dpi(192, 192), 1.0, false, true);
152 assert
.deepEqual(pluginSize
, size(640 * 3 / 2.0, 480 * 3 / 2.0));
154 // 5. Client dimensions larger than host's by >2x.
155 pluginSize
= remoting
.Viewport
.choosePluginSize(
156 size(1280, 1024), 2.0, size(640, 480), dpi(192, 192), 1.0, false, true);
157 assert
.deepEqual(pluginSize
, size(1280, (1280 / 640) * 480));
159 // 6. Client X dimension larger than host's, Y dimension smaller.
160 pluginSize
= remoting
.Viewport
.choosePluginSize(
161 size(1152, 600), 2.0, size(1024, 768), dpi(192, 192), 1.0, false, true);
162 assert
.deepEqual(pluginSize
, size(1024 / 2.0, 768 / 2.0));
165 QUnit
.test('choosePluginSize() handles high-DPI client, 150% DPI host',
167 // 1. Client & host size the same.
168 var pluginSize
= remoting
.Viewport
.choosePluginSize(
169 size(640, 480), 2.0, size(640, 480), dpi(144, 144), 1.0, false, true);
170 assert
.deepEqual(pluginSize
, size(640, 480));
172 // 2. Client dimensions smaller than host's.
173 pluginSize
= remoting
.Viewport
.choosePluginSize(
174 size(640, 480), 2.0, size(1024, 600), dpi(144, 144), 1.0, false, true);
175 assert
.deepEqual(pluginSize
, size(1024 / 2.0, 600 / 2.0));
177 // 3. Client Y dimension larger than host's, X dimension smaller.
178 pluginSize
= remoting
.Viewport
.choosePluginSize(
179 size(640, 640), 2.0, size(1024, 600), dpi(144, 144), 1.0, false, true);
180 assert
.deepEqual(pluginSize
, size(1024 / 2.0, 600 / 2.0));
182 // 4. Client dimensions larger than host's by <2x.
183 // Host dimensions fit into the client's _device_ dimensions 3x, so the
184 // size in client DIPs should be 1:3/2.
185 pluginSize
= remoting
.Viewport
.choosePluginSize(
186 size(1280, 900), 2.0, size(640, 480), dpi(144, 144), 1.0, false, true);
187 assert
.deepEqual(pluginSize
, size(640 * 3 / 2.0, 480 * 3 / 2.0));
189 // 5. Client dimensions larger than host's by >2x.
190 pluginSize
= remoting
.Viewport
.choosePluginSize(
191 size(1280, 1024), 2.0, size(640, 480), dpi(144, 144), 1.0, false, true);
192 assert
.deepEqual(pluginSize
, size(1280, (1280 / 640) * 480));
194 // 6. Client X dimension larger than host's, Y dimension smaller.
195 pluginSize
= remoting
.Viewport
.choosePluginSize(
196 size(1152, 600), 2.0, size(1024, 768), dpi(144, 144), 1.0, false, true);
197 assert
.deepEqual(pluginSize
, size(1024 / 2.0, 768 / 2.0));
200 QUnit
.test('choosePluginSize() handles high-DPI client, 125% DPI host',
202 // 1. Client & host size the same.
203 var pluginSize
= remoting
.Viewport
.choosePluginSize(
204 size(640, 480), 2.0, size(640, 480), dpi(120, 120), 1.0, false, true);
205 assert
.deepEqual(pluginSize
, size(640, 480));
207 // 2. Client dimensions smaller than host's.
208 pluginSize
= remoting
.Viewport
.choosePluginSize(
209 size(640, 480), 2.0, size(1024, 600), dpi(120, 120), 1.0, false, true);
210 assert
.deepEqual(pluginSize
, size(640, 600 * (640 / 1024)));
212 // 3. Client Y dimension larger than host's, X dimension smaller.
213 pluginSize
= remoting
.Viewport
.choosePluginSize(
214 size(640, 640), 2.0, size(1024, 600), dpi(120, 120), 1.0, false, true);
215 assert
.deepEqual(pluginSize
, size(640, 600 * (640 / 1024)));
217 // 4. Client dimensions larger than host's by <2x.
218 // Host dimensions fit into the client's _device_ dimensions 3x, so the
219 // size in client DIPs should be 1:3/2.
220 pluginSize
= remoting
.Viewport
.choosePluginSize(
221 size(1280, 900), 2.0, size(640, 480), dpi(120, 120), 1.0, false, true);
222 assert
.deepEqual(pluginSize
, size(640 * 3 / 2.0, 480 * 3 / 2.0));
224 // 5. Client dimensions larger than host's by >2x.
225 pluginSize
= remoting
.Viewport
.choosePluginSize(
226 size(1280, 1024), 2.0, size(640, 480), dpi(120, 120), 1.0, false, true);
227 assert
.deepEqual(pluginSize
, size(1280, (1280 / 640) * 480));
229 // 6. Client X dimension larger than host's, Y dimension smaller.
230 pluginSize
= remoting
.Viewport
.choosePluginSize(
231 size(1152, 600), 2.0, size(1024, 768), dpi(120, 120), 1.0, false, true);
232 assert
.deepEqual(pluginSize
, size(1024 * (600 / 768), 600));
235 QUnit
.test('choosePluginSize() with shrink-to-fit disabled',
237 // 1. Client & host size the same.
238 var pluginSize
= remoting
.Viewport
.choosePluginSize(
239 size(640, 480), 1.0, size(640, 480), dpi(96, 96), 1.0, false, false);
240 assert
.deepEqual(pluginSize
, size(640, 480));
242 // 2. Client logical dimensions smaller than host's.
243 pluginSize
= remoting
.Viewport
.choosePluginSize(
244 size(640, 480), 1.0, size(1024, 600), dpi(96, 96), 1.0, false, false);
245 assert
.deepEqual(pluginSize
, size(1024, 600));
247 // 3. Client dimensions larger than host's by <2x.
248 pluginSize
= remoting
.Viewport
.choosePluginSize(
249 size(1280, 900), 1.0, size(640, 480), dpi(96, 96), 1.0, false, false);
250 assert
.deepEqual(pluginSize
, size(640, 480));
252 // 4. Client dimensions larger than host's by >2x.
253 pluginSize
= remoting
.Viewport
.choosePluginSize(
254 size(1280, 1024), 1.0, size(640, 480), dpi(96, 96), 1.0, false, false);
255 assert
.deepEqual(pluginSize
, size(1280, (1280 / 640) * 480));
257 // 5. Client smaller than host, client high-DPI, host low-DPI.
258 pluginSize
= remoting
.Viewport
.choosePluginSize(
259 size(640, 480), 2.0, size(1024, 600), dpi(96, 96), 1.0, false, false);
260 assert
.deepEqual(pluginSize
, size(1024, 600));
262 // 6. Client smaller than host, client low-DPI, host high-DPI.
263 pluginSize
= remoting
.Viewport
.choosePluginSize(
264 size(640, 480), 1.0, size(1024, 600), dpi(192, 192), 1.0, false, false);
265 assert
.deepEqual(pluginSize
, size(1024, 600));
267 // 7. Client smaller than host, both high-DPI.
268 pluginSize
= remoting
.Viewport
.choosePluginSize(
269 size(640, 480), 2.0, size(1024, 600), dpi(192, 192), 1.0, false, false);
270 assert
.deepEqual(pluginSize
, size(512, (512 / 1024) * 600));
272 // 8. Client smaller than host, client high-DPI, host 150% DPI.
273 pluginSize
= remoting
.Viewport
.choosePluginSize(
274 size(640, 480), 2.0, size(1024, 600), dpi(144, 144), 1.0, false, false);
275 assert
.deepEqual(pluginSize
, size(512, (512 / 1024) * 600));
278 QUnit
.test('choosePluginSize() full-screen multi-monitor optimization',
280 // Each test has a host sized to approximate two or more monitors.
282 // 1. Client & host per-monitor dimensions match, two monitors side-by-side.
283 var pluginSize
= remoting
.Viewport
.choosePluginSize(
284 size(640, 480), 1.0, size(2 * 640, 480), dpi(96, 96), 1.0, true, true);
285 assert
.deepEqual(pluginSize
, size(2 * 640, 480));
287 // 2. Client & host per-monitor dimensions match, two monitors stacked.
288 pluginSize
= remoting
.Viewport
.choosePluginSize(
289 size(640, 480), 1.0, size(640, 2 * 480), dpi(96, 96), 1.0, true, true);
290 assert
.deepEqual(pluginSize
, size(640, 2 * 480));
292 // 3. Client larger, two monitors stacked.
293 pluginSize
= remoting
.Viewport
.choosePluginSize(
294 size(1024, 768), 1.0, size(640, 2 * 480), dpi(96, 96), 1.0, true, true);
295 assert
.deepEqual(pluginSize
, size(640 * (768 / (2 * 480)), 768));
297 // 4. Client smaller, two monitors stacked.
298 pluginSize
= remoting
.Viewport
.choosePluginSize(
299 size(640, 480), 1.0, size(1024, 2 * 768), dpi(96, 96), 1.0, true, true);
300 assert
.deepEqual(pluginSize
, size(640, 2 * 768 * (640 / 1024)));
302 // 5. Client wide-screen, host two standard monitors stacked.
303 pluginSize
= remoting
.Viewport
.choosePluginSize(
304 size(1920, 1080), 1.0, size(1024, 2 * 768), dpi(96, 96), 1.0,
306 assert
.deepEqual(pluginSize
, size(1024 * (1080 / (2 * 768)), 1080));
308 // 6. Client & host per-monitor dimensions match, two monitors stacked,
310 pluginSize
= remoting
.Viewport
.choosePluginSize(
311 size(640, 480), 2.0, size(640, 2 * 480), dpi(96, 96), 1.0, true, true);
312 assert
.deepEqual(pluginSize
, size(640, 2 * 480));
314 // 7. Client & host per-monitor dimensions match, two monitors stacked,
316 pluginSize
= remoting
.Viewport
.choosePluginSize(
317 size(640, 480), 1.0, size(640, 2 * 480), dpi(192, 192),
319 assert
.deepEqual(pluginSize
, size(640, 2 * 480));
321 // 8. Client & host per-monitor dimensions match, two monitors stacked,
322 // high-DPI client & host.
323 pluginSize
= remoting
.Viewport
.choosePluginSize(
324 size(640, 480), 2.0, size(640, 2 * 480), dpi(192, 192),
326 assert
.deepEqual(pluginSize
, size(640 / 2.0, (2 * 480) / 2.0));