17ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski/*
27ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski * Copyright (C) 2010 The Android Open Source Project
37ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski *
47ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski * Licensed under the Apache License, Version 2.0 (the "License");
57ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski * you may not use this file except in compliance with the License.
67ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski * You may obtain a copy of the License at
77ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski *
87ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski *      http://www.apache.org/licenses/LICENSE-2.0
97ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski *
107ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski * Unless required by applicable law or agreed to in writing, software
117ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski * distributed under the License is distributed on an "AS IS" BASIS,
127ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
137ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski * See the License for the specific language governing permissions and
147ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski * limitations under the License.
157ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski */
167ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski
177ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowskipackage com.android.dumprendertree2;
187ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski
197ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowskiimport android.app.Service;
207ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowskiimport android.content.Intent;
215f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowskiimport android.os.Bundle;
225f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowskiimport android.os.Environment;
237ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowskiimport android.os.Handler;
247ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowskiimport android.os.IBinder;
257ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowskiimport android.os.Message;
267ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowskiimport android.os.Messenger;
277ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowskiimport android.util.Log;
287ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski
295f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowskiimport java.io.File;
30c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowskiimport java.util.ArrayList;
31c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowskiimport java.util.List;
325f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
337ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski/**
347ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski * A service that handles managing the results of tests, informing of crashes, generating
357ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski * summaries, etc.
367ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski */
377ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowskipublic class ManagerService extends Service {
387ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski
397ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski    private static final String LOG_TAG = "ManagerService";
407ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski
41bcf114c2bbef4dd4af266a635a74076d568d125cMaksymilian Osowski    private static final int MSG_CRASH_TIMEOUT_EXPIRED = 0;
429893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski    private static final int MSG_SUMMARIZER_DONE = 1;
4323a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski
4423a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    private static final int CRASH_TIMEOUT_MS = 20 * 1000;
4523a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski
465f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    /** TODO: make it a setting */
475f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    static final String RESULTS_ROOT_DIR_PATH =
48bdebd0621b2a4422a30bea21ea549afd20a9e918Steve Block            Environment.getExternalStorageDirectory() + File.separator + "layout-test-results";
495f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
505f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    /** TODO: Make it a setting */
51c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski    private static final List<String> EXPECTED_RESULT_LOCATION_RELATIVE_DIR_PREFIXES =
52c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski            new ArrayList<String>(3);
53c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski    {
54c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski        EXPECTED_RESULT_LOCATION_RELATIVE_DIR_PREFIXES.add("platform" + File.separator +
55c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski                "android-v8" + File.separator);
56c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski        EXPECTED_RESULT_LOCATION_RELATIVE_DIR_PREFIXES.add("platform" + File.separator +
57c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski                "android" + File.separator);
58c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski        EXPECTED_RESULT_LOCATION_RELATIVE_DIR_PREFIXES.add("");
59c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski    }
605f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
615f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    /** TODO: Make these settings */
625f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    private static final String TEXT_RESULT_EXTENSION = "txt";
635f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    private static final String IMAGE_RESULT_EXTENSION = "png";
645f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
657ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski    static final int MSG_PROCESS_ACTUAL_RESULTS = 0;
665f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    static final int MSG_ALL_TESTS_FINISHED = 1;
6723a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    static final int MSG_FIRST_TEST = 2;
68bcf114c2bbef4dd4af266a635a74076d568d125cMaksymilian Osowski    static final int MSG_CURRENT_TEST_CRASHED = 3;
699eed25e2576403a91826312381f4507e8c8171c2Steve Block    static final int MSG_RESET = 4;
707ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski
7123a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    /**
7223a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski     * This handler is purely for IPC. It is used to create mMessenger
7323a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski     * that generates a binder returned in onBind method.
7423a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski     */
757ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski    private Handler mIncomingHandler = new Handler() {
767ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski        @Override
777ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski        public void handleMessage(Message msg) {
787ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski            switch (msg.what) {
799eed25e2576403a91826312381f4507e8c8171c2Steve Block                case MSG_RESET:
80ea46f2595a8718d4478e016fd40b2d57658289cfMaksymilian Osowski                    mSummarizer.reset();
819eed25e2576403a91826312381f4507e8c8171c2Steve Block                    break;
829eed25e2576403a91826312381f4507e8c8171c2Steve Block
839eed25e2576403a91826312381f4507e8c8171c2Steve Block                case MSG_FIRST_TEST:
8423a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski                    Bundle bundle = msg.getData();
8523a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski                    ensureNextTestSetup(bundle.getString("firstTest"), bundle.getInt("index"));
8623a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski                    break;
8723a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski
887ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski                case MSG_PROCESS_ACTUAL_RESULTS:
892e5982a55ac031110ed39515a76f7a5ec9ff2c14Maksymilian Osowski                    Log.d(LOG_TAG,"mIncomingHandler: " + msg.getData().getString("relativePath"));
905f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski                    onActualResultsObtained(msg.getData());
915f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski                    break;
925f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
93bcf114c2bbef4dd4af266a635a74076d568d125cMaksymilian Osowski                case MSG_CURRENT_TEST_CRASHED:
949893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                    mInternalMessagesHandler.removeMessages(MSG_CRASH_TIMEOUT_EXPIRED);
95bcf114c2bbef4dd4af266a635a74076d568d125cMaksymilian Osowski                    onTestCrashed();
96bcf114c2bbef4dd4af266a635a74076d568d125cMaksymilian Osowski                    break;
97bcf114c2bbef4dd4af266a635a74076d568d125cMaksymilian Osowski
985f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski                case MSG_ALL_TESTS_FINISHED:
999893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                    /** We run it in a separate thread to avoid ANR */
1009893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                    new Thread() {
1019893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                        @Override
1029893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                        public void run() {
1039893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                            mSummarizer.setTestsRelativePath(mAllTestsRelativePath);
1049893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                            Message msg = Message.obtain(mInternalMessagesHandler,
1059893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                                    MSG_SUMMARIZER_DONE);
1069893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                            mSummarizer.summarize(msg);
1079893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                        }
1089893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                    }.start();
1097ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski            }
1107ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski        }
1117ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski    };
1127ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski
1137ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski    private Messenger mMessenger = new Messenger(mIncomingHandler);
1147ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski
1159893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski    private Handler mInternalMessagesHandler = new Handler() {
11623a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        @Override
11723a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        public void handleMessage(Message msg) {
1189893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski            switch (msg.what) {
1199893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                case MSG_CRASH_TIMEOUT_EXPIRED:
1209893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                    onTestCrashed();
1219893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                    break;
1229893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski
1239893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                case MSG_SUMMARIZER_DONE:
1249893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                    Intent intent = new Intent(ManagerService.this, TestsListActivity.class);
1259893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                    intent.setAction(Intent.ACTION_SHUTDOWN);
1269893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                    /** This flag is needed because we send the intent from the service */
1279893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                    intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
1289893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                    startActivity(intent);
1299893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski                    break;
13023a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski            }
13123a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        }
13223a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    };
13323a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski
1345f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    private Summarizer mSummarizer;
1355f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
13623a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    private String mCurrentlyRunningTest;
13723a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    private int mCurrentlyRunningTestIndex;
13823a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski
13901c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski    /**
14001c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski     * These are implementation details of getExpectedResultPath() used to reduce the number
14101c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski     * of requests required to the host server.
14201c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski     */
14301c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski    private String mLastExpectedResultPathRequested;
14401c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski    private String mLastExpectedResultPathFetched;
14501c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski
1462e64bb7afdd97c954491877306ccb8318f8ec3ceMaksymilian Osowski    private String mAllTestsRelativePath;
1472e64bb7afdd97c954491877306ccb8318f8ec3ceMaksymilian Osowski
1487ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski    @Override
1497ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski    public void onCreate() {
1507ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski        super.onCreate();
1515f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
152cda9448206494b67c0812b9591cc066ca070a7a6Steve Block        mSummarizer = new Summarizer(RESULTS_ROOT_DIR_PATH, getApplicationContext());
1537ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski    }
1547ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski
1557ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski    @Override
15623a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    public int onStartCommand(Intent intent, int flags, int startId) {
1572e64bb7afdd97c954491877306ccb8318f8ec3ceMaksymilian Osowski        mAllTestsRelativePath = intent.getStringExtra("path");
1582e64bb7afdd97c954491877306ccb8318f8ec3ceMaksymilian Osowski        assert mAllTestsRelativePath != null;
15923a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        return START_STICKY;
16023a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    }
16123a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski
16223a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    @Override
1637ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski    public IBinder onBind(Intent intent) {
1647ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski        return mMessenger.getBinder();
1657ddc0b7a72aa66d699fecce3d855a6c70f844647Maksymilian Osowski    }
1665f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
1675f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    private void onActualResultsObtained(Bundle bundle) {
1689893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski        mInternalMessagesHandler.removeMessages(MSG_CRASH_TIMEOUT_EXPIRED);
16923a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        ensureNextTestSetup(bundle.getString("nextTest"), bundle.getInt("testIndex") + 1);
17023a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski
1715f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        AbstractResult results =
1725f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski                AbstractResult.TestType.valueOf(bundle.getString("type")).createResult(bundle);
17323a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski
1742e5982a55ac031110ed39515a76f7a5ec9ff2c14Maksymilian Osowski        Log.i(LOG_TAG, "onActualResultObtained: " + results.getRelativePath());
17523a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        handleResults(results);
17623a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    }
17723a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski
17823a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    private void ensureNextTestSetup(String nextTest, int index) {
17923a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        if (nextTest == null) {
1802e5982a55ac031110ed39515a76f7a5ec9ff2c14Maksymilian Osowski            Log.w(LOG_TAG, "ensureNextTestSetup(): nextTest=null");
18123a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski            return;
18223a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        }
18323a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski
18423a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        mCurrentlyRunningTest = nextTest;
18523a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        mCurrentlyRunningTestIndex = index;
1869893d96d1231235f3d984e9dc751f08409a5f873Maksymilian Osowski        mInternalMessagesHandler.sendEmptyMessageDelayed(MSG_CRASH_TIMEOUT_EXPIRED, CRASH_TIMEOUT_MS);
18723a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    }
18823a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski
18923a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    /**
19023a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski     * This sends an intent to TestsListActivity to restart LayoutTestsExecutor.
19123a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski     * The more detailed description of the flow is in the comment of onNewIntent
19223a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski     * method in TestsListActivity.
19323a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski     */
19423a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    private void onTestCrashed() {
19523a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        handleResults(new CrashedDummyResult(mCurrentlyRunningTest));
19623a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski
1972e5982a55ac031110ed39515a76f7a5ec9ff2c14Maksymilian Osowski        Log.w(LOG_TAG, "onTestCrashed(): " + mCurrentlyRunningTest +
1982e5982a55ac031110ed39515a76f7a5ec9ff2c14Maksymilian Osowski                " (" + mCurrentlyRunningTestIndex + ")");
19923a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski
20023a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        Intent intent = new Intent(this, TestsListActivity.class);
20123a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        intent.setAction(Intent.ACTION_REBOOT);
202c8fb818b947f15d4eb467c229ea43806dd75c01eMaksymilian Osowski        /** This flag is needed because we send the intent from the service */
203c8fb818b947f15d4eb467c229ea43806dd75c01eMaksymilian Osowski        intent.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
20423a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        intent.putExtra("crashedTestIndex", mCurrentlyRunningTestIndex);
20523a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        startActivity(intent);
20623a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    }
20723a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski
20823a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski    private void handleResults(AbstractResult results) {
2095f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        String relativePath = results.getRelativePath();
2105f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        results.setExpectedTextResult(getExpectedTextResult(relativePath));
21101c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski        results.setExpectedTextResultPath(getExpectedTextResultPath(relativePath));
2125f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        results.setExpectedImageResult(getExpectedImageResult(relativePath));
21301c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski        results.setExpectedImageResultPath(getExpectedImageResultPath(relativePath));
2145f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
2155f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        dumpActualTextResult(results);
2165f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        dumpActualImageResult(results);
2175f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
2185f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        mSummarizer.appendTest(results);
2195f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    }
2205f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
2215f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    private void dumpActualTextResult(AbstractResult result) {
2225f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        String testPath = result.getRelativePath();
2235f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        String actualTextResult = result.getActualTextResult();
2245f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        if (actualTextResult == null) {
2255f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski            return;
2265f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        }
2275f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
2285f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        String resultPath = FileFilter.setPathEnding(testPath, "-actual." + TEXT_RESULT_EXTENSION);
2295f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        FsUtils.writeDataToStorage(new File(RESULTS_ROOT_DIR_PATH, resultPath),
2305f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski                actualTextResult.getBytes(), false);
2315f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    }
2325f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
2335f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    private void dumpActualImageResult(AbstractResult result) {
2345f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        String testPath = result.getRelativePath();
2355f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        byte[] actualImageResult = result.getActualImageResult();
2365f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        if (actualImageResult == null) {
2375f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski            return;
2385f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        }
2395f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
24023a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski        String resultPath = FileFilter.setPathEnding(testPath,
24123a0ee4758da5e2d24ec6c9e8a63c127463a096fMaksymilian Osowski                "-actual." + IMAGE_RESULT_EXTENSION);
2425f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        FsUtils.writeDataToStorage(new File(RESULTS_ROOT_DIR_PATH, resultPath),
2435f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski                actualImageResult, false);
2445f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    }
2455f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
24601c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski    public String getExpectedTextResult(String relativePath) {
247dd4bff62b54033bedc254f517397ae8f954d0dc9Maksymilian Osowski        byte[] result = getExpectedResult(relativePath, TEXT_RESULT_EXTENSION);
248dd4bff62b54033bedc254f517397ae8f954d0dc9Maksymilian Osowski        if (result != null) {
249dd4bff62b54033bedc254f517397ae8f954d0dc9Maksymilian Osowski            return new String(result);
250dd4bff62b54033bedc254f517397ae8f954d0dc9Maksymilian Osowski        }
251dd4bff62b54033bedc254f517397ae8f954d0dc9Maksymilian Osowski        return null;
2525f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    }
2535f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
25401c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski    public byte[] getExpectedImageResult(String relativePath) {
2555f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        return getExpectedResult(relativePath, IMAGE_RESULT_EXTENSION);
2565f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    }
2575f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
25801c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski    private byte[] getExpectedResult(String relativePath, String extension) {
259c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski        String originalRelativePath =
260c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski                FileFilter.setPathEnding(relativePath, "-expected." + extension);
26101c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski        mLastExpectedResultPathRequested = originalRelativePath;
262c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski
263c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski        byte[] bytes = null;
264c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski        List<String> locations = EXPECTED_RESULT_LOCATION_RELATIVE_DIR_PREFIXES;
2655f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
266c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski        int size = EXPECTED_RESULT_LOCATION_RELATIVE_DIR_PREFIXES.size();
267c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski        for (int i = 0; bytes == null && i < size; i++) {
268c83712e68642b9816a561916c6ec044509bd6759Maksymilian Osowski            relativePath = locations.get(i) + originalRelativePath;
269ca501d20360ffee3a37fc87538daf8281f8a14edSteve Block            bytes = FsUtils.readDataFromUrl(FileFilter.getUrl(relativePath, false));
2705f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        }
2715f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski
272f460dd42190ada4a2c147db5127a9d7870fe0101Steve Block        mLastExpectedResultPathFetched = bytes == null ? null : relativePath;
2735f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski        return bytes;
2745f0ccd76a88586ce85c17cb4db058934e693a4fcMaksymilian Osowski    }
27501c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski
27601c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski    private String getExpectedTextResultPath(String relativePath) {
27701c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski        return getExpectedResultPath(relativePath, TEXT_RESULT_EXTENSION);
27801c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski    }
27901c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski
28001c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski    private String getExpectedImageResultPath(String relativePath) {
28101c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski        return getExpectedResultPath(relativePath, IMAGE_RESULT_EXTENSION);
28201c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski    }
28301c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski
28401c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski    private String getExpectedResultPath(String relativePath, String extension) {
28501c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski        String originalRelativePath =
28601c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski            FileFilter.setPathEnding(relativePath, "-expected." + extension);
28701c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski        if (!originalRelativePath.equals(mLastExpectedResultPathRequested)) {
28801c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski            getExpectedResult(relativePath, extension);
28901c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski        }
29001c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski
29101c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski        return mLastExpectedResultPathFetched;
29201c1f9d9e9e7ab3a40a9bf27195a434eb0c9bb9bMaksymilian Osowski    }
29334c68912be678ad50a70c1bfa54a91444e993df5Steve Block}
294