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

Side by Side Diff: components/cronet/android/test/javatests/src/org/chromium/net/ExperimentalOptionsTest.java

Issue 1833203002: Plumb SSLKEYLOGFILE from Cronet to net (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address comment Created 4 years, 8 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
OLDNEW
(Empty)
1 // Copyright 2016 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 package org.chromium.net;
6
7 import android.test.suitebuilder.annotation.SmallTest;
8
9 import org.chromium.base.PathUtils;
10 import org.chromium.base.test.util.Feature;
11 import org.chromium.net.CronetTestBase.OnlyRunNativeCronet;
12 import org.json.JSONObject;
13
14 import java.io.BufferedReader;
15 import java.io.File;
16 import java.io.FileReader;
17
18 /**
19 * Tests for experimental options.
20 */
21 public class ExperimentalOptionsTest extends CronetTestBase {
22 private static final String TAG = "cr.QuicTest";
23 private CronetTestFramework mTestFramework;
24 private CronetEngine.Builder mBuilder;
25
26 @Override
27 protected void setUp() throws Exception {
28 super.setUp();
29 System.loadLibrary("cronet_tests");
30 mBuilder = new CronetEngine.Builder(getContext());
31 mBuilder.setMockCertVerifierForTesting(QuicTestServer.createMockCertVeri fier());
32 assertTrue(Http2TestServer.startHttp2TestServer(
33 getContext(), QuicTestServer.getServerCert(), QuicTestServer.get ServerCertKey()));
34 }
35
36 @Override
37 protected void tearDown() throws Exception {
38 assertTrue(Http2TestServer.shutdownHttp2TestServer());
39 if (mTestFramework.mCronetEngine != null) {
40 mTestFramework.mCronetEngine.shutdown();
41 }
42 super.tearDown();
43 }
44
45 @SmallTest
46 @Feature({"Cronet"})
47 @OnlyRunNativeCronet
48 public void testSetSSLKeyLogFile() throws Exception {
49 String url = Http2TestServer.getEchoMethodUrl();
50 File dir = new File(PathUtils.getDataDirectory(getContext()));
51 File file = File.createTempFile("ssl_key_log_file", "", dir);
52
53 JSONObject experimentalOptions = new JSONObject().put("ssl_key_log_file" , file.getPath());
54 mBuilder.setExperimentalOptions(experimentalOptions.toString());
55 mTestFramework = new CronetTestFramework(null, null, getContext(), mBuil der);
56
57 TestUrlRequestCallback callback = new TestUrlRequestCallback();
58 UrlRequest.Builder builder = new UrlRequest.Builder(
59 url, callback, callback.getExecutor(), mTestFramework.mCronetEng ine);
60 UrlRequest urlRequest = builder.build();
61 urlRequest.start();
62 callback.blockForDone();
63 assertEquals(200, callback.mResponseInfo.getHttpStatusCode());
64 assertEquals("GET", callback.mResponseAsString);
65
66 assertTrue(file.exists());
67 assertTrue(file.length() != 0);
68 BufferedReader logReader = new BufferedReader(new FileReader(file));
69 boolean validFile = false;
70 try {
71 String logLine;
72 while ((logLine = logReader.readLine()) != null) {
73 if (logLine.contains("CLIENT_RANDOM")) {
74 validFile = true;
75 break;
76 }
77 }
78 } finally {
79 logReader.close();
80 }
81 assertTrue(validFile);
82 assertTrue(file.delete());
83 assertTrue(!file.exists());
84 }
85 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698