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

Side by Side Diff: webrtc/examples/androidtests/src/org/appspot/apprtc/test/FileVideoCapturerTest.java

Issue 2405463002: Testing of FileVideoCapturer (Closed)
Patch Set: y Created 4 years, 2 months 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
« no previous file with comments | « webrtc/examples/BUILD.gn ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 /*
2 * Copyright 2016 The WebRTC Project Authors. All rights reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11 package org.appspot.apprtc.test;
12
13 import android.test.InstrumentationTestCase;
14 import android.test.suitebuilder.annotation.LargeTest;
15 import android.test.suitebuilder.annotation.MediumTest;
16 import android.test.suitebuilder.annotation.SmallTest;
17
18 import org.webrtc.FileVideoCapturer;
19 import org.webrtc.VideoCapturer;
20
21 import java.io.IOException;
22 import java.lang.Thread;
23 import java.util.ArrayList;
24 import java.util.Random;
25
26 public class FileVideoCapturerTest extends InstrumentationTestCase {
27 private static class Frame {
28 public byte[] data;
29 public int width;
30 public int height;
31 }
32
33 public class MockCapturerObserver implements VideoCapturer.CapturerObserver {
34 private ArrayList<Frame> frameDatas = new ArrayList<Frame>();
magjed_webrtc 2016/10/20 14:55:33 Make this variable final.
mandermo 2016/10/24 18:08:02 Done.
35
36 public void onCapturerStarted(boolean success) {
magjed_webrtc 2016/10/20 14:55:33 Annotate every function with @Override.
mandermo 2016/10/24 18:08:02 Done.
37 // Empty on purpose
magjed_webrtc 2016/10/20 14:55:33 assertTrue on success
mandermo 2016/10/24 18:08:02 Done.
38 }
39
40 public void onCapturerStopped() {
41 // Empty on purpose
magjed_webrtc 2016/10/20 14:55:33 Add a dot at the end of every sentence in comments
mandermo 2016/10/24 18:08:02 Done.
42 }
43
44 public synchronized void onByteBufferFrameCaptured(
45 byte[] data, int width, int height, int rotation, long timeStamp) {
46 Frame frame = new Frame();
47 frame.data = data;
48 frame.width = width;
49 frame.height = height;
50 assertTrue(data.length != 0);
51 frameDatas.add(frame);
52 notify();
53 }
54
55 public void onTextureFrameCaptured(int width, int height, int oesTextureId,
56 float[] transformMatrix, int rotation, long timestamp) {
57 // Empty on purpose
58 }
59
60 public void onOutputFormatRequest(int width, int height, int framerate) {
magjed_webrtc 2016/10/20 14:55:33 This function is no longer part of the interface,
61 // Empty on purpose
62 }
63
64 public synchronized ArrayList<Frame> getMinimumFramesBlocking(int minFrames)
65 throws InterruptedException {
66 while (frameDatas.size() < minFrames) {
67 wait();
68 }
69 return new ArrayList<Frame>(frameDatas);
70 }
71 }
72
73 @SmallTest
74 public void testVideoCaptureFromFile() throws InterruptedException, IOExceptio n {
75 final int FRAME_WIDTH = 640;
76 final int FRAME_HEIGHT = 360;
77 FileVideoCapturer fileVideoCapturer = new FileVideoCapturer(
78 "/sdcard/chromium_tests_root/resources/reference_video_640x360_30fps_4fr ames.y4m");
79 MockCapturerObserver capturerObserver = new MockCapturerObserver();
80 fileVideoCapturer.initialize(null, null, capturerObserver);
81 fileVideoCapturer.startCapture(4, 4, 33);
82
83 // The expected data at the pseudo randomly choosen positions
84 String[] expectedFrames = {
85 "7C543C7D7C6C86B31055787FA03F5CE7B0507D5AA42A7B5E867E4462977F99707F95",
86 "CF864F7F7E6C416975871E687673857CA56B88DA7E6F4D991C62A4B7537B7D978E95",
87 "918CA66F877DDE7473A8817E7F7C7E38807D7971E7977F6B877D417B7E7C808E408F",
88 "597D8B4772436380A6388380B6AC7E869E58B46A7B78AB722E6C298B6C66A8678375"};
89
90 ArrayList<Frame> frameDatas;
91 try {
92 frameDatas = capturerObserver.getMinimumFramesBlocking(expectedFrames.leng th);
93 } catch (InterruptedException e) {
94 throw new RuntimeException(e);
95 }
96 assertTrue(expectedFrames.length == frameDatas.size());
97
98 fileVideoCapturer.stopCapture();
99 fileVideoCapturer.dispose();
100
101 for (int i = 0; i < expectedFrames.length; ++i) {
magjed_webrtc 2016/10/20 14:55:33 Since it's impossible to verify this manually anyw
mandermo 2016/10/24 18:08:02 Now use hashing approach. Using small file is also
magjed_webrtc 2016/10/25 08:02:47 Yes, a small file would be optimal. Can you do the
102 Frame frame = frameDatas.get(i);
103 // Same seed everytime
104 Random random = new Random(i);
105
106 assertEquals(FRAME_WIDTH, frame.width);
107 assertEquals(FRAME_HEIGHT, frame.height);
108 assertEquals(FRAME_WIDTH * FRAME_HEIGHT * 3 / 2, frame.data.length);
109
110 StringBuilder builder = new StringBuilder();
111 for (int k = 0; k < expectedFrames[i].length() / 2; ++k) {
112 int pos = random.nextInt(frame.data.length);
113 builder.append(String.format("%02X", frame.data[pos]));
114 }
115
116 assertEquals(expectedFrames[i], builder.toString());
117 }
118 }
119 }
OLDNEW
« no previous file with comments | « webrtc/examples/BUILD.gn ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698