This file is indexed.

/usr/lib/python3/dist-packages/plainbox/qml_shell/qml_shell.qml is in python3-plainbox 0.25-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 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
93
94
95
96
/*
 * This file is part of Checkbox
 *
 * Copyright 2014 Canonical Ltd.
 *
 * Authors:
 * - Maciej Kisielewski <maciej.kisielewski@canonical.com>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; version 3.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */
/*! \brief QML standalone shell

    This component serves as QML shell that embeds native QML plainbox jobs.
    The job it loads is specified by --job argument passed to qmlscene
    launching this component.
    Job to be run must have testingShell property that be used as a hook to
    'outside world'. The job should also define testDone signal that gets
    signalled once test is finished. The signal should pass result object
    containing following fields:
    'outcome' (mandatory): outcome of a test, e.g. 'pass', 'fail', 'undecided'.
    'suggestedOutcome': if outcome is 'undecided', than this suggestion will be
    presented to the user, letting them decide the final outcome of a test.
*/
import QtQuick 2.0
import Ubuntu.Components 1.1
import io.thp.pyotherside 1.4

MainView {
    id: mainView
    width: units.gu(100)
    height: units.gu(75)

    // information and functionality passed to qml job component
    property var testingShell: {
        "name": "Standalone testing shell",
        "pageStack": pageStack,
        "python": py
    }

    Arguments {
        id: args
        Argument {
            name: "job"
            help: "QML-native job to run"
            required: true
            valueNames: ["PATH"]
        }
    }
    Python {
        id: py
    }

    Loader {
        id: loader
        anchors.fill: parent
        onLoaded: loader.item.testDone.connect(testDone)
        onStatusChanged: {
            if (loader.status === Loader.Error) {
                testDone({'outcome': 'crash'});
                grimReaper.start();
            }
        }
    }

    PageStack {
        id: pageStack
    }

    Timer {
        /* because loader is constructed synchronously when the app is started,
         * Qt.quit() would fire a signal that engine hasn't yet connected to.
         * By using this timer we deffer calling of Qt.quit() */
        id: grimReaper
        interval: 10
        onTriggered: Qt.quit()
    }

    function testDone(res) {
        console.error("__test_result_object:"+JSON.stringify(res));
        Qt.quit();
    }

    Component.onCompleted: {
        loader.setSource(args.values.job, {'testingShell': testingShell});
    }
}