diff options
Diffstat (limited to 'sdkmanager/libs/sdkuilib/tests/com/android/sdkuilib/internal/repository/ui/SdkManagerUpgradeTest.java')
-rwxr-xr-x | sdkmanager/libs/sdkuilib/tests/com/android/sdkuilib/internal/repository/ui/SdkManagerUpgradeTest.java | 203 |
1 files changed, 203 insertions, 0 deletions
diff --git a/sdkmanager/libs/sdkuilib/tests/com/android/sdkuilib/internal/repository/ui/SdkManagerUpgradeTest.java b/sdkmanager/libs/sdkuilib/tests/com/android/sdkuilib/internal/repository/ui/SdkManagerUpgradeTest.java new file mode 100755 index 0000000..00d9684 --- /dev/null +++ b/sdkmanager/libs/sdkuilib/tests/com/android/sdkuilib/internal/repository/ui/SdkManagerUpgradeTest.java @@ -0,0 +1,203 @@ +/* + * Copyright (C) 2012 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package com.android.sdkuilib.internal.repository.ui; + +import com.android.sdklib.SdkManager; +import com.android.sdklib.SdkManagerTestCase; +import com.android.sdklib.repository.SdkRepoConstants; +import com.android.sdkuilib.internal.repository.MockDownloadCache; +import com.android.sdkuilib.internal.repository.MockUpdaterData; + +import java.util.Arrays; + +public class SdkManagerUpgradeTest extends SdkManagerTestCase { + + @Override + public void setUp() throws Exception { + super.setUp(); + } + + @Override + public void tearDown() throws Exception { + super.tearDown(); + } + + /** + * Create a mock page and list the current SDK state + */ + public void testPackagesPage1() throws Exception { + SdkManager sdkman = getSdkManager(); + + MockUpdaterData updaterData = new MockUpdaterData(sdkman); + MockDownloadCache cache = (MockDownloadCache) updaterData.getDownloadCache(); + updaterData.setupDefaultSources(); + + MockPackagesPageImpl pageImpl = new MockPackagesPageImpl(updaterData); + pageImpl.postCreate(); + pageImpl.performFirstLoad(); + + // We have no network access possible and no mock download cache items. + // The only thing visible in the display are the local packages as set by + // the fake locally-installed SDK. + String actual = pageImpl.getMockTreeDisplay(); + assertEquals( + "[] Tools | | | \n" + + " L_[] Android SDK Tools | | 0 | Installed\n" + + "[] Android 0.0 (API 0) | | | \n" + + " L_[] SDK Platform | | 1 | Installed\n" + + " L_[] Sources for Android SDK | | 0 | Installed\n" + + "[] Extras | | | ", + actual); + + assertEquals( + "[]", // there are no direct downloads till we try to install. + Arrays.toString(cache.getDirectHits())); + assertEquals( + "[<https://dl-ssl.google.com/android/repository/addons_list-1.xml : 1>, " + + "<https://dl-ssl.google.com/android/repository/addons_list-2.xml : 1>, " + + "<https://dl-ssl.google.com/android/repository/repository-5.xml : 2>, " + + "<https://dl-ssl.google.com/android/repository/repository-6.xml : 2>, " + + "<https://dl-ssl.google.com/android/repository/repository-7.xml : 2>, " + + "<https://dl-ssl.google.com/android/repository/repository.xml : 2>]", + Arrays.toString(cache.getCachedHits())); + + + // Now prepare a tools update on the server and reload + setupToolsXml1(cache); + cache.clearDirectHits(); + cache.clearCachedHits(); + pageImpl.fullReload(); + + actual = pageImpl.getMockTreeDisplay(); + assertEquals( + "[] Tools | | | \n" + + " L_[] Android SDK Tools | | 0 | Update available: rev. 20.0.3\n" + + " L_[] Android SDK Platform-tools | | 14 | Not installed \n" + + "[] Android 0.0 (API 0) | | | \n" + + " L_[] SDK Platform | | 1 | Installed \n" + + " L_[] Sources for Android SDK | | 0 | Installed \n" + + "[] Extras | | | ", + actual); + + assertEquals( + "[]", // there are no direct downloads till we try to install. + Arrays.toString(cache.getDirectHits())); + assertEquals( + "[<https://dl-ssl.google.com/android/repository/repository-5.xml : 1>, " + + "<https://dl-ssl.google.com/android/repository/repository-6.xml : 1>, " + + "<https://dl-ssl.google.com/android/repository/repository-7.xml : 1>, " + + "<https://dl-ssl.google.com/android/repository/repository.xml : 1>]", + Arrays.toString(cache.getCachedHits())); + + + // We should get the same display if we restart the manager page from scratch + // (e.g. simulate a first load) + + cache.clearDirectHits(); + cache.clearCachedHits(); + pageImpl = new MockPackagesPageImpl(updaterData); + pageImpl.postCreate(); + pageImpl.performFirstLoad(); + + actual = pageImpl.getMockTreeDisplay(); + assertEquals( + "[] Tools | | | \n" + + " L_[] Android SDK Tools | | 0 | Update available: rev. 20.0.3\n" + + " L_[] Android SDK Platform-tools | | 14 | Not installed \n" + + "[] Android 0.0 (API 0) | | | \n" + + " L_[] SDK Platform | | 1 | Installed \n" + + " L_[] Sources for Android SDK | | 0 | Installed \n" + + "[] Extras | | | ", + actual); + + assertEquals( + "[]", // there are no direct downloads till we try to install. + Arrays.toString(cache.getDirectHits())); + assertEquals( + "[<https://dl-ssl.google.com/android/repository/repository-5.xml : 1>, " + + "<https://dl-ssl.google.com/android/repository/repository-6.xml : 1>, " + + "<https://dl-ssl.google.com/android/repository/repository-7.xml : 1>, " + + "<https://dl-ssl.google.com/android/repository/repository.xml : 1>]", + Arrays.toString(cache.getCachedHits())); + } + + private void setupToolsXml1(MockDownloadCache cache) throws Exception { + String repoXml = + "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" + + "<sdk:sdk-repository xmlns:sdk=\"http://schemas.android.com/sdk/android/repository/7\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\">\n" + + "<sdk:license id=\"android-sdk-license\" type=\"text\">Blah blah blah.</sdk:license>\n" + + "\n" + + "<sdk:platform-tool>\n" + + " <sdk:revision>\n" + + " <sdk:major>14</sdk:major>\n" + + " </sdk:revision>\n" + + " <sdk:archives>\n" + + " <sdk:archive arch=\"any\" os=\"windows\">\n" + + " <sdk:size>11159472</sdk:size>\n" + + " <sdk:checksum type=\"sha1\">6028258d8f2fba14d8b40c3cf507afa0289aaa13</sdk:checksum>\n" + + " <sdk:url>platform-tools_r14-windows.zip</sdk:url>\n" + + " </sdk:archive>\n" + + " <sdk:archive arch=\"any\" os=\"linux\">\n" + + " <sdk:size>10985068</sdk:size>\n" + + " <sdk:checksum type=\"sha1\">6e2bc329c9485eb383172cbc2cde8b0c0cd1843f</sdk:checksum>\n" + + " <sdk:url>platform-tools_r14-linux.zip</sdk:url>\n" + + " </sdk:archive>\n" + + " <sdk:archive arch=\"any\" os=\"macosx\">\n" + + " <sdk:size>11342461</sdk:size>\n" + + " <sdk:checksum type=\"sha1\">4a015090c6a209fc33972acdbc65745e0b3c08b9</sdk:checksum>\n" + + " <sdk:url>platform-tools_r14-macosx.zip</sdk:url>\n" + + " </sdk:archive>\n" + + " </sdk:archives>\n" + + "</sdk:platform-tool>\n" + + "\n" + + "<sdk:tool>\n" + + " <sdk:revision>\n" + + " <sdk:major>20</sdk:major>\n" + + " <sdk:minor>0</sdk:minor>\n" + + " <sdk:micro>3</sdk:micro>\n" + + " </sdk:revision>\n" + + " <sdk:min-platform-tools-rev>\n" + + " <sdk:major>12</sdk:major>\n" + + " </sdk:min-platform-tools-rev>\n" + + " <sdk:archives>\n" + + " <sdk:archive arch=\"any\" os=\"windows\">\n" + + " <sdk:size>90272048</sdk:size>\n" + + " <sdk:checksum type=\"sha1\">54fb94168e631e211910f88aa40c532205730dd4</sdk:checksum>\n" + + " <sdk:url>tools_r20.0.3-windows.zip</sdk:url>\n" + + " </sdk:archive>\n" + + " <sdk:archive arch=\"any\" os=\"linux\">\n" + + " <sdk:size>82723559</sdk:size>\n" + + " <sdk:checksum type=\"sha1\">09bc633b406ae81981e3a0db19426acbb01ef219</sdk:checksum>\n" + + " <sdk:url>tools_r20.0.3-linux.zip</sdk:url>\n" + + " </sdk:archive>\n" + + " <sdk:archive arch=\"any\" os=\"macosx\">\n" + + " <sdk:size>58197071</sdk:size>\n" + + " <sdk:checksum type=\"sha1\">09cee5ff3226277a6f0c07dcd29cba4ffc2e1da4</sdk:checksum>\n" + + " <sdk:url>tools_r20.0.3-macosx.zip</sdk:url>\n" + + " </sdk:archive>\n" + + " </sdk:archives>\n" + + "</sdk:tool>\n" + + "\n" + + "</sdk:sdk-repository>\n"; + + String url = SdkRepoConstants.URL_GOOGLE_SDK_SITE + + String.format(SdkRepoConstants.URL_DEFAULT_FILENAME, SdkRepoConstants.NS_LATEST_VERSION); + + cache.registerCachedPayload(url, repoXml.getBytes("UTF-8")); + } + +} |