summaryrefslogtreecommitdiff
path: root/apexd/flattened_apex_test.cpp
blob: e4ec6635db9461854679631fc32647fc5f93a0d0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
/*
 * Copyright (C) 2019 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.
 */

#include <android-base/file.h>
#include <android-base/logging.h>
#include <android-base/strings.h>

#include <gtest/gtest.h>
#include <filesystem>
#include <memory>

#include <ApexProperties.sysprop.h>
#include "apex_constants.h"
#include "apex_shim.h"
#include "apexd_utils.h"
#include "string_log.h"

namespace android {
namespace apex {

TEST(FlattenedApexTest, SysPropIsFalse) {
  bool value = android::sysprop::ApexProperties::updatable().value_or(false);
  ASSERT_FALSE(value);
}

TEST(FlattenedApexTest, ApexFilesAreFlattened) {
  namespace fs = std::filesystem;
  auto assert_is_dir = [&](const fs::directory_entry& entry) {
    if (entry.path().filename() == shim::kSystemShimApexName) {
      return;
    }
    std::error_code ec;
    bool is_dir = entry.is_directory(ec);
    ASSERT_FALSE(ec) << ec.message();
    ASSERT_TRUE(is_dir) << entry.path() << " is not a directory";
  };
  WalkDir(kApexPackageSystemDir, assert_is_dir);
}

TEST(FlattenedApexTest, MountsAreCorrect) {
  using android::base::ReadFileToString;
  using android::base::Split;
  std::string mounts;
  ASSERT_TRUE(ReadFileToString("/proc/self/mountinfo", &mounts));
  bool has_apex_mount = false;
  for (const auto& mount : Split(mounts, "\n")) {
    const std::vector<std::string>& tokens = Split(mount, " ");
    // line format:
    // mnt_id parent_mnt_id major:minor source target option propagation_type
    if (tokens.size() < 7) {
      continue;
    }
    const std::string& source = tokens[3];
    const std::string& target = tokens[4];
    if (source == kApexPackageSystemDir && target == "/apex") {
      has_apex_mount = true;
    }
  }
  ASSERT_TRUE(has_apex_mount) << "Failed to find apex mount point";
}

TEST(FlattenedApexTest, ApexdIsNotRunning) {
  constexpr const char* kCmd = "pidof -s apexd";
  std::unique_ptr<FILE, int (*)(FILE*)> pipe(popen(kCmd, "r"), pclose);
  ASSERT_NE(nullptr, pipe) << "Failed to open pipe for: " << kCmd;
  char buf[1024];
  if (fgets(buf, 1024, pipe.get()) != nullptr) {
    FAIL() << "apexd is running and has pid " << buf;
  }
}

}  // namespace apex
}  // namespace android

int main(int argc, char** argv) {
  android::base::InitLogging(argv, &android::base::StderrLogger);
  ::testing::InitGoogleTest(&argc, argv);
  return RUN_ALL_TESTS();
}