xref: /aosp_15_r20/external/autotest/site_utils/lxc.py (revision 9c5db1993ded3edbeafc8092d69fe5de2ee02df7)
1*9c5db199SXin Li# Copyright 2015 The Chromium Authors. All rights reserved.
2*9c5db199SXin Li# Use of this source code is governed by a BSD-style license that can be
3*9c5db199SXin Li# found in the LICENSE file.
4*9c5db199SXin Li
5*9c5db199SXin Li"""This tool can be used to set up a base container for test. For example,
6*9c5db199SXin Li  python lxc.py -s -p /tmp/container
7*9c5db199SXin LiThis command will download and setup base container in directory /tmp/container.
8*9c5db199SXin LiAfter that command finishes, you can run lxc command to work with the base
9*9c5db199SXin Licontainer, e.g.,
10*9c5db199SXin Li  lxc-start -P /tmp/container -n base -d
11*9c5db199SXin Li  lxc-attach -P /tmp/container -n base
12*9c5db199SXin Li"""
13*9c5db199SXin Li
14*9c5db199SXin Liimport argparse
15*9c5db199SXin Liimport logging
16*9c5db199SXin Li
17*9c5db199SXin Liimport common
18*9c5db199SXin Lifrom autotest_lib.client.bin import utils
19*9c5db199SXin Lifrom autotest_lib.site_utils import lxc
20*9c5db199SXin Lifrom autotest_lib.site_utils.lxc import base_image
21*9c5db199SXin Li
22*9c5db199SXin Li
23*9c5db199SXin Lidef parse_options():
24*9c5db199SXin Li    """Parse command line inputs.
25*9c5db199SXin Li
26*9c5db199SXin Li    @raise argparse.ArgumentError: If command line arguments are invalid.
27*9c5db199SXin Li    """
28*9c5db199SXin Li    parser = argparse.ArgumentParser()
29*9c5db199SXin Li    parser.add_argument('-s', '--setup', action='store_true',
30*9c5db199SXin Li                        default=False,
31*9c5db199SXin Li                        help='Set up base container.')
32*9c5db199SXin Li    parser.add_argument('-p',
33*9c5db199SXin Li                        '--path',
34*9c5db199SXin Li                        type=str,
35*9c5db199SXin Li                        help='Directory to store the container.',
36*9c5db199SXin Li                        default=lxc.DEFAULT_BASE_CONTAINER_PATH)
37*9c5db199SXin Li    parser.add_argument('-f', '--force_delete', action='store_true',
38*9c5db199SXin Li                        default=False,
39*9c5db199SXin Li                        help=('Force to delete existing containers and rebuild '
40*9c5db199SXin Li                              'base containers.'))
41*9c5db199SXin Li    parser.add_argument('-n', '--name', type=str,
42*9c5db199SXin Li                        help='Name of the base container.',
43*9c5db199SXin Li                        default=lxc.BASE)
44*9c5db199SXin Li    options = parser.parse_args()
45*9c5db199SXin Li    if not options.setup and not options.force_delete:
46*9c5db199SXin Li        raise argparse.ArgumentError(
47*9c5db199SXin Li            'Use --setup to setup a base container, or --force_delete to '
48*9c5db199SXin Li            'delete all containers in given path.')
49*9c5db199SXin Li    return options
50*9c5db199SXin Li
51*9c5db199SXin Li
52*9c5db199SXin Lidef main():
53*9c5db199SXin Li    """main script."""
54*9c5db199SXin Li    # Force to run the setup as superuser.
55*9c5db199SXin Li    # TODO(dshi): crbug.com/459344 Set remove this enforcement when test
56*9c5db199SXin Li    # container can be unprivileged container.
57*9c5db199SXin Li    if utils.sudo_require_password():
58*9c5db199SXin Li        logging.warning('SSP requires root privilege to run commands, please '
59*9c5db199SXin Li                     'grant root access to this process.')
60*9c5db199SXin Li        utils.run('sudo true')
61*9c5db199SXin Li
62*9c5db199SXin Li    options = parse_options()
63*9c5db199SXin Li    image = base_image.BaseImage(options.path, lxc.BASE)
64*9c5db199SXin Li    if options.setup:
65*9c5db199SXin Li        image.setup(name=options.name, force_delete=options.force_delete)
66*9c5db199SXin Li    elif options.force_delete:
67*9c5db199SXin Li        image.cleanup()
68*9c5db199SXin Li
69*9c5db199SXin Li
70*9c5db199SXin Liif __name__ == '__main__':
71*9c5db199SXin Li    main()
72