|  | #!/bin/bash | 
|  | # Copyright 2019 The Fuchsia Authors. All rights reserved. | 
|  | # Use of this source code is governed by a BSD-style license that can be | 
|  | # found in the LICENSE file. | 
|  |  | 
|  | ### Test expected usage of device-finder in fx scripts | 
|  |  | 
|  |  | 
|  | BT_FILE_DEPS=( | 
|  | "scripts/fx" | 
|  | "tools/devshell/lib/fx-cmd-locator.sh" | 
|  | "tools/devshell/lib/fx-optional-features.sh" | 
|  | "tools/devshell/lib/vars.sh" | 
|  | "tools/devshell/lib/platform.sh" | 
|  | "tools/devshell/host-tool" | 
|  | ) | 
|  |  | 
|  | BT_MOCKED_TOOLS=( | 
|  | "tools/devshell/list-build-artifacts" | 
|  | "tools/devshell/build" | 
|  | ) | 
|  |  | 
|  | declare fx devfinder | 
|  |  | 
|  | BT_SET_UP() { | 
|  | source "${BT_TEMP_DIR}/tools/devshell/tests/lib/fuchsia-mock.sh" | 
|  | fx="$(btf::setup_fx)" | 
|  | source "${BT_TEMP_DIR}/tools/devshell/lib/vars.sh" | 
|  | fx-config-read | 
|  | devfinder="$(btf::make_installed_hosttools_mock device-finder)" | 
|  | devfinder_rel="${devfinder##${FUCHSIA_BUILD_DIR}/}" | 
|  | cat >"${BT_TEMP_DIR}/tools/devshell/list-build-artifacts.mock_side_effects" <<EOF | 
|  | [[ \$2 == "device-finder" ]] && echo ${devfinder_rel} && exit 0 | 
|  | exit 1 | 
|  | EOF | 
|  |  | 
|  | } | 
|  |  | 
|  | TEST_tool_executed() { | 
|  | BT_EXPECT ${fx} host-tool "device-finder" "--flag1" "arg1" | 
|  | btf::expect-mock-args "${devfinder}" "--flag1" "arg1" | 
|  | } | 
|  |  | 
|  | TEST_tool_not_built() { | 
|  | BT_EXPECT ${fx} host-tool "device-finder" "--flag1" "arg1" | 
|  | # tool exists, so build should not be called | 
|  | BT_ASSERT_FILE_DOES_NOT_EXIST "${BT_TEMP_DIR}/tools/devshell/build.mock_state" | 
|  | } | 
|  |  | 
|  | TEST_force_build() { | 
|  | BT_EXPECT ${fx} host-tool --force-build "device-finder" "--flag1" "arg1" | 
|  | # tool exists, but build should be called anyway because --force-build | 
|  | BT_ASSERT_FILE_EXISTS "${BT_TEMP_DIR}/tools/devshell/build.mock_state" | 
|  | } | 
|  |  | 
|  | TEST_build_if_not_found() { | 
|  | # tool does not exist, but is known to the build, so build should be called | 
|  | mv "${devfinder}" "${devfinder}_backup" | 
|  |  | 
|  | # recreate the tool when 'fx build' is called | 
|  | cat >"${BT_TEMP_DIR}/tools/devshell/build.mock_side_effects" <<EOF | 
|  | mv "${devfinder}_backup" "${devfinder}" | 
|  | EOF | 
|  |  | 
|  | BT_EXPECT ${fx} host-tool "device-finder" "--flag1" "arg1" | 
|  | BT_ASSERT_FILE_EXISTS "${BT_TEMP_DIR}/tools/devshell/build.mock_state" | 
|  | btf::expect-mock-args "${devfinder}" "--flag1" "arg1" | 
|  | } | 
|  |  | 
|  | TEST_no_build() { | 
|  | # tool does not exist, is known to the build, but --no-build is specified | 
|  | mv "${devfinder}" "${devfinder}_backup" | 
|  |  | 
|  | # should fail because tool cannot be found | 
|  | BT_EXPECT_FAIL ${fx} host-tool "--no-build" "device-finder" "--flag1" "arg1" 2> /dev/null | 
|  |  | 
|  | # ensure that build was not called | 
|  | BT_ASSERT_FILE_DOES_NOT_EXIST "${BT_TEMP_DIR}/tools/devshell/build.mock_state" | 
|  | } | 
|  |  | 
|  | BT_RUN_TESTS "$@" |