Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2017 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.content.Context; | |
| 8 import android.support.test.filters.SmallTest; | |
| 9 | |
| 10 import static org.chromium.net.CronetProviders.PROVIDER_NAME_NATIVE; | |
| 11 import static org.chromium.net.CronetProviders.PROVIDER_NAME_PLATFORM; | |
| 12 | |
| 13 import org.chromium.base.test.util.Feature; | |
| 14 | |
| 15 import java.util.ArrayList; | |
| 16 import java.util.Arrays; | |
| 17 import java.util.List; | |
| 18 | |
| 19 /** | |
| 20 * Tests {@link CronetEngine.Builder}. | |
| 21 */ | |
| 22 public class CronetEngineBuilderTest extends CronetTestBase { | |
| 23 /** | |
| 24 * Tests the comparison of two strings that contain versions. | |
| 25 */ | |
| 26 @SmallTest | |
| 27 @Feature({"Cronet"}) | |
| 28 @CronetTestBase.OnlyRunNativeCronet | |
| 29 public void testVersionComparison() { | |
| 30 assertVersionIsHigher("22.44", "22.43.12"); | |
| 31 assertVersionIsLower("22.43.12", "022.124"); | |
| 32 assertVersionIsLower("22.99", "22.100"); | |
| 33 assertVersionIsHigher("22.100", "22.99"); | |
| 34 assertVersionIsEqual("11.2.33", "11.2.33"); | |
| 35 assertIllegalArgumentException(null, "1.2.3"); | |
| 36 assertIllegalArgumentException("1.2.3", null); | |
| 37 assertIllegalArgumentException("1.2.3", "1.2.3x"); | |
| 38 } | |
| 39 | |
| 40 /** | |
| 41 * Tests the correct ordering of the providers. The platform provider should be | |
| 42 * the last in the list. Other providers should be ordered by placing provid ers | |
| 43 * with the higher version first. | |
| 44 */ | |
| 45 @SmallTest | |
| 46 @Feature({"Cronet"}) | |
| 47 @CronetTestBase.OnlyRunNativeCronet | |
| 48 public void testProviderOrdering() { | |
| 49 final CronetProvider[] availableProviders = new CronetProvider[] { | |
| 50 new FakeProvider(getContext(), PROVIDER_NAME_NATIVE, "99.77", tr ue), | |
| 51 new FakeProvider(getContext(), PROVIDER_NAME_PLATFORM, "99.99", true), | |
| 52 new FakeProvider(getContext(), "Some other provider", "99.88", t rue), | |
| 53 }; | |
| 54 int[] expectedPositions = {1, 2, 0}; | |
| 55 | |
| 56 CronetProviders providers = new FakeProviders(availableProviders); | |
| 57 List<CronetProvider> orderedProviders = | |
| 58 CronetEngine.Builder.getEnabledCronetProviders(getContext(), pro viders); | |
| 59 | |
| 60 // Check the result. | |
| 61 for (int i = 0; i < availableProviders.length; i++) { | |
|
mef
2017/01/19 22:57:46
Can this just be assertEquals(PROVIDER_NAME_NATIVE
kapishnikov
2017/01/20 16:21:54
Good point. Done.
| |
| 62 int expectedPosition = expectedPositions[i]; | |
| 63 assertEquals("i=" + i + ". Provider '" + availableProviders[i] | |
| 64 + "' should be at position " + expectedPosition + ". ", | |
| 65 availableProviders[i], orderedProviders.get(expectedPosition )); | |
| 66 } | |
| 67 } | |
| 68 | |
| 69 /** | |
| 70 * Tests that the providers that are disabled are not included in the list o f available | |
| 71 * providers when the provider is selected by the default selection logic. | |
| 72 */ | |
| 73 @SmallTest | |
| 74 @Feature({"Cronet"}) | |
| 75 @CronetTestBase.OnlyRunNativeCronet | |
|
mef
2017/01/19 22:57:46
Why is it marked OnlyRunNativeCronet? Would runnin
kapishnikov
2017/01/20 16:21:54
Done.
| |
| 76 public void testThatDisabledProvidersAreExcluded() { | |
| 77 final CronetProvider[] availableProviders = new CronetProvider[] { | |
| 78 new FakeProvider(getContext(), PROVIDER_NAME_PLATFORM, "99.99", true), | |
| 79 new FakeProvider(getContext(), PROVIDER_NAME_NATIVE, "99.77", tr ue), | |
| 80 new FakeProvider(getContext(), "Some other provider", "99.88", f alse), | |
| 81 }; | |
| 82 | |
| 83 CronetProviders providers = new FakeProviders(availableProviders); | |
| 84 List<CronetProvider> orderedProviders = | |
| 85 CronetEngine.Builder.getEnabledCronetProviders(getContext(), pro viders); | |
| 86 | |
| 87 assertEquals("Unexpected number of providers in the list", 2, orderedPro viders.size()); | |
| 88 assertEquals(PROVIDER_NAME_NATIVE, orderedProviders.get(0).getName()); | |
| 89 assertEquals(PROVIDER_NAME_PLATFORM, orderedProviders.get(1).getName()); | |
| 90 } | |
| 91 | |
| 92 private void assertVersionIsHigher(String s1, String s2) { | |
| 93 assertEquals(1, CronetEngine.Builder.compareVersions(s1, s2)); | |
| 94 } | |
| 95 | |
| 96 private void assertVersionIsLower(String s1, String s2) { | |
| 97 assertEquals(-1, CronetEngine.Builder.compareVersions(s1, s2)); | |
| 98 } | |
| 99 | |
| 100 private void assertVersionIsEqual(String s1, String s2) { | |
| 101 assertEquals(0, CronetEngine.Builder.compareVersions(s1, s2)); | |
| 102 } | |
| 103 | |
| 104 private void assertIllegalArgumentException(String s1, String s2) { | |
| 105 try { | |
| 106 CronetEngine.Builder.compareVersions(s1, s2); | |
| 107 } catch (IllegalArgumentException e) { | |
| 108 // Do nothing. It is expected. | |
| 109 return; | |
| 110 } | |
| 111 fail("Expected IllegalArgumentException"); | |
| 112 } | |
| 113 | |
| 114 // TODO(kapishnikov): Replace with a mock when mockito is supported. | |
|
mef
2017/01/19 22:57:46
FWIW it seems that mockito is already supported: h
kapishnikov
2017/01/20 16:21:54
The components that use mockito run junit tests (i
| |
| 115 private static class FakeProvider extends CronetProvider { | |
| 116 private final String mName; | |
| 117 private final String mVersion; | |
| 118 private final boolean mEnabled; | |
| 119 | |
| 120 protected FakeProvider(Context context, String name, String version, boo lean enabled) { | |
| 121 super(context); | |
| 122 mName = name; | |
| 123 mVersion = version; | |
| 124 mEnabled = enabled; | |
| 125 } | |
| 126 | |
| 127 @Override | |
| 128 public CronetEngine.Builder createBuilder() { | |
| 129 return new CronetEngine.Builder((ICronetEngineBuilder) null); | |
| 130 } | |
| 131 | |
| 132 @Override | |
| 133 public String getName() { | |
| 134 return mName; | |
| 135 } | |
| 136 | |
| 137 @Override | |
| 138 public String getVersion() { | |
| 139 return mVersion; | |
| 140 } | |
| 141 | |
| 142 @Override | |
| 143 public boolean isEnabled() { | |
| 144 return mEnabled; | |
| 145 } | |
| 146 | |
| 147 @Override | |
| 148 public String toString() { | |
| 149 return mName; | |
| 150 } | |
| 151 } | |
| 152 | |
| 153 // TODO(kapishnikov): Replace with a mock when mockito is supported. | |
|
mef
2017/01/19 22:57:46
unused?
kapishnikov
2017/01/20 16:21:54
The class is used in testProviderOrdering() and te
| |
| 154 private static class FakeProviders extends CronetProviders { | |
| 155 final List<CronetProvider> mList; | |
| 156 | |
| 157 private FakeProviders(CronetProvider[] providers) { | |
| 158 mList = new ArrayList<>(Arrays.asList(providers)); | |
| 159 } | |
| 160 | |
| 161 @Override | |
| 162 public List<CronetProvider> getAvailableProviders(Context context) { | |
| 163 return mList; | |
| 164 } | |
| 165 } | |
| 166 } | |
| OLD | NEW |