summaryrefslogtreecommitdiff
path: root/src/buildstream/_scheduler/jobs/cleanupjob.py
blob: 672e784bc94465881e83b39808c197f0582b2c92 (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
#  Copyright (C) 2018 Codethink Limited
#
#  This program is free software; you can redistribute it and/or
#  modify it under the terms of the GNU Lesser General Public
#  License as published by the Free Software Foundation; either
#  version 2 of the License, or (at your option) any later version.
#
#  This library 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
#  Lesser General Public License for more details.
#
#  You should have received a copy of the GNU Lesser General Public
#  License along with this library. If not, see <http://www.gnu.org/licenses/>.
#
#  Author:
#        Tristan Daniƫl Maat <tristan.maat@codethink.co.uk>
#
from .job import Job, JobStatus, ChildJob


class CleanupJob(Job):
    def __init__(self, *args, complete_cb, **kwargs):
        super().__init__(*args, **kwargs)
        self._complete_cb = complete_cb

        context = self._scheduler.context
        self._casquota = context.get_casquota()

    def handle_message(self, message_type, message):
        # Update the cache size in the main process as we go,
        # this provides better feedback in the UI.
        if message_type == 'update-cache-size':
            self._casquota.set_cache_size(message, write_to_disk=False)
            return True

        return False

    def parent_complete(self, status, result):
        if status == JobStatus.OK:
            self._casquota.set_cache_size(result, write_to_disk=False)

        if self._complete_cb:
            self._complete_cb(status, result)

    def create_child_job(self, *args, **kwargs):
        return ChildCleanupJob(*args, casquota=self._scheduler.context.get_casquota(), **kwargs)


class ChildCleanupJob(ChildJob):
    def __init__(self, *args, casquota, **kwargs):
        super().__init__(*args, **kwargs)
        self._casquota = casquota

    def child_process(self):
        def progress():
            self.send_message('update-cache-size',
                              self._casquota.get_cache_size())
        return self._casquota.clean(progress)