blob: 325d1af56aadf523737d113bfe847349bfad47e9 [file] [log] [blame]
Alex Deymoaea4c1c2015-08-19 20:24:43 -07001//
2// Copyright (C) 2012 The Android Open Source Project
3//
4// Licensed under the Apache License, Version 2.0 (the "License");
5// you may not use this file except in compliance with the License.
6// You may obtain a copy of the License at
7//
8// http://www.apache.org/licenses/LICENSE-2.0
9//
10// Unless required by applicable law or agreed to in writing, software
11// distributed under the License is distributed on an "AS IS" BASIS,
12// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13// See the License for the specific language governing permissions and
14// limitations under the License.
15//
rspangler@google.com49fdf182009-10-10 00:57:34 +000016
17// based on pam_google_testrunner.cc
18
Darin Petkov9c0baf82010-10-07 13:44:48 -070019#include <base/at_exit.h>
20#include <base/command_line.h>
Alex Deymo0bb23412015-06-19 00:04:46 -070021#include <chromeos/test_helpers.h>
rspangler@google.com49fdf182009-10-10 00:57:34 +000022#include <gtest/gtest.h>
Darin Petkov9c0baf82010-10-07 13:44:48 -070023
Darin Petkov9c0baf82010-10-07 13:44:48 -070024#include "update_engine/terminator.h"
adlr@google.comc98a7ed2009-12-04 18:54:03 +000025
rspangler@google.com49fdf182009-10-10 00:57:34 +000026int main(int argc, char **argv) {
Gilad Arnoldfc359292012-04-30 22:04:24 -070027 LOG(INFO) << "started";
Darin Petkov5c0a8af2010-08-24 13:39:13 -070028 base::AtExitManager exit_manager;
Gilad Arnold0b4a6ff2012-04-30 13:13:03 -070029 // TODO(garnold) temporarily cause the unittest binary to exit with status
30 // code 2 upon catching a SIGTERM. This will help diagnose why the unittest
31 // binary is perceived as failing by the buildbot. We should revert it to use
32 // the default exit status of 1. Corresponding reverts are necessary in
33 // terminator_unittest.cc.
34 chromeos_update_engine::Terminator::Init(2);
Gilad Arnoldfc359292012-04-30 22:04:24 -070035 LOG(INFO) << "parsing command line arguments";
Alex Vakulenkob96ecda2015-04-02 14:31:10 -070036 base::CommandLine::Init(argc, argv);
Gilad Arnoldfc359292012-04-30 22:04:24 -070037 LOG(INFO) << "initializing gtest";
Alex Deymo0bb23412015-06-19 00:04:46 -070038 SetUpTests(&argc, argv, true);
Gilad Arnoldfc359292012-04-30 22:04:24 -070039 LOG(INFO) << "running unit tests";
Gilad Arnoldfaac2a52012-04-26 14:44:17 -070040 int test_result = RUN_ALL_TESTS();
41 LOG(INFO) << "unittest return value: " << test_result;
42 return test_result;
rspangler@google.com49fdf182009-10-10 00:57:34 +000043}