isolate.gypi revision 5d1f7b1de12d16ceb2c938c56701a3e8bfa558f7
1# Copyright (c) 2012 The Chromium Authors. All rights reserved.
2# Use of this source code is governed by a BSD-style license that can be
3# found in the LICENSE file.
4
5# This file is meant to be included into a target to provide a rule
6# to "build" .isolate files into a .isolated file.
7#
8# To use this, create a gyp target with the following form:
9# 'conditions': [
10#   ['test_isolation_mode != "noop"', {
11#     'targets': [
12#       {
13#         'target_name': 'foo_test_run',
14#         'type': 'none',
15#         'dependencies': [
16#           'foo_test',
17#         ],
18#         'includes': [
19#           '../build/isolate.gypi',
20#           'foo_test.isolate',
21#         ],
22#         'sources': [
23#           'foo_test.isolate',
24#         ],
25#       },
26#     ],
27#   }],
28# ],
29#
30# Note: foo_test.isolate is included and a source file. It is an inherent
31# property of the .isolate format. This permits to define GYP variables but is
32# a stricter format than GYP so isolate.py can read it.
33#
34# The generated .isolated file will be:
35#   <(PRODUCT_DIR)/foo_test.isolated
36#
37# See http://dev.chromium.org/developers/testing/isolated-testing/for-swes
38# for more information.
39
40{
41  'includes': [
42    '../chrome/version.gypi',
43  ],
44  'rules': [
45    {
46      'rule_name': 'isolate',
47      'extension': 'isolate',
48      'inputs': [
49        # Files that are known to be involved in this step.
50        '<(DEPTH)/tools/swarming_client/isolate.py',
51        '<(DEPTH)/tools/swarming_client/run_isolated.py',
52
53        # Disable file tracking by the build driver for now. This means the
54        # project must have the proper build-time dependency for their runtime
55        # dependency. This improves the runtime of the build driver since it
56        # doesn't have to stat() all these files.
57        #
58        # More importantly, it means that even if a isolate_dependency_tracked
59        # file is missing, for example if a file was deleted and the .isolate
60        # file was not updated, that won't break the build, especially in the
61        # case where foo_tests_run is not built! This should be reenabled once
62        # the switch-over to running tests on Swarm is completed.
63        #'<@(isolate_dependency_tracked)',
64      ],
65      'outputs': [
66        '<(PRODUCT_DIR)/<(RULE_INPUT_ROOT).isolated',
67      ],
68      'action': [
69        'python',
70        '<(DEPTH)/tools/swarming_client/isolate.py',
71        '<(test_isolation_mode)',
72        '--result', '<@(_outputs)',
73        '--isolate', '<(RULE_INPUT_PATH)',
74
75        # Variables should use the -V FOO=<(FOO) form so frequent values,
76        # like '0' or '1', aren't stripped out by GYP. Run 'isolate.py help' for
77        # more details.
78        #
79        # This list needs to be kept in sync with the cmd line options
80        # in src/build/android/pylib/gtest/setup.py.
81
82        # Path variables are used to replace file paths when loading a .isolate
83        # file
84        '--path-variable', 'PRODUCT_DIR', '<(PRODUCT_DIR) ',
85
86        # Extra variables are replaced on the 'command' entry and on paths in
87        # the .isolate file but are not considered relative paths.
88        '--extra-variable', 'version_full=<(version_full)',
89
90        '--config-variable', 'OS=<(OS)',
91        '--config-variable', 'chromeos=<(chromeos)',
92        '--config-variable', 'component=<(component)',
93        # TODO(kbr): move this to chrome_tests.gypi:gles2_conform_tests_run
94        # once support for user-defined config variables is added.
95        '--config-variable',
96          'internal_gles2_conform_tests=<(internal_gles2_conform_tests)',
97        '--config-variable', 'icu_use_data_file_flag=<(icu_use_data_file_flag)',
98        '--config-variable', 'libpeer_target_type=<(libpeer_target_type)',
99        '--config-variable', 'use_openssl=<(use_openssl)',
100      ],
101      'conditions': [
102        # Note: When gyp merges lists, it appends them to the old value.
103        ['OS=="mac"', {
104          # <(mac_product_name) can contain a space, so don't use FOO=<(FOO)
105          # form.
106          'action': [
107            '--extra-variable', 'mac_product_name', '<(mac_product_name)',
108          ],
109        }],
110        ["test_isolation_outdir!=''", {
111          'action': [ '--isolate-server', '<(test_isolation_outdir)' ],
112        }],
113        ['test_isolation_fail_on_missing == 0', {
114          'action': ['--ignore_broken_items'],
115        }],
116      ],
117    },
118  ],
119}
120