diff options
Diffstat (limited to 'bitbake/lib/toaster/toastermain/management/commands')
4 files changed, 99 insertions, 0 deletions
diff --git a/bitbake/lib/toaster/toastermain/management/commands/__init__.py b/bitbake/lib/toaster/toastermain/management/commands/__init__.py new file mode 100644 index 0000000000..e69de29bb2 --- /dev/null +++ b/bitbake/lib/toaster/toastermain/management/commands/__init__.py | |||
diff --git a/bitbake/lib/toaster/toastermain/management/commands/builddelete.py b/bitbake/lib/toaster/toastermain/management/commands/builddelete.py new file mode 100644 index 0000000000..5cec436714 --- /dev/null +++ b/bitbake/lib/toaster/toastermain/management/commands/builddelete.py | |||
@@ -0,0 +1,33 @@ | |||
1 | from django.core.management.base import BaseCommand, CommandError | ||
2 | from orm.models import Build | ||
3 | import os | ||
4 | |||
5 | |||
6 | |||
7 | class Command(BaseCommand): | ||
8 | args = "buildId" | ||
9 | help = "Deletes selected build" | ||
10 | |||
11 | def handle(self, buildId, *args, **options): | ||
12 | b = Build.objects.get(pk = buildId) | ||
13 | # theoretically, just b.delete() would suffice | ||
14 | # however SQLite runs into problems when you try to | ||
15 | # delete too many rows at once, so we delete some direct | ||
16 | # relationships from Build manually. | ||
17 | |||
18 | for t in b.target_set.all(): | ||
19 | t.delete() | ||
20 | for t in b.task_build.all(): | ||
21 | t.delete() | ||
22 | for p in b.package_set.all(): | ||
23 | p.delete() | ||
24 | for lv in b.layer_version_build.all(): | ||
25 | lv.delete() | ||
26 | for v in b.variable_build.all(): | ||
27 | v.delete() | ||
28 | for l in b.logmessage_set.all(): | ||
29 | l.delete() | ||
30 | |||
31 | # this should take care of the rest | ||
32 | b.delete() | ||
33 | |||
diff --git a/bitbake/lib/toaster/toastermain/management/commands/buildslist.py b/bitbake/lib/toaster/toastermain/management/commands/buildslist.py new file mode 100644 index 0000000000..cad987fd93 --- /dev/null +++ b/bitbake/lib/toaster/toastermain/management/commands/buildslist.py | |||
@@ -0,0 +1,13 @@ | |||
1 | from django.core.management.base import NoArgsCommand, CommandError | ||
2 | from orm.models import Build | ||
3 | import os | ||
4 | |||
5 | |||
6 | |||
7 | class Command(NoArgsCommand): | ||
8 | args = "" | ||
9 | help = "Lists current builds" | ||
10 | |||
11 | def handle_noargs(self,**options): | ||
12 | for b in Build.objects.all(): | ||
13 | print "%d: %s %s %s" % (b.pk, b.machine, b.distro, ",".join([x.target for x in b.target_set.all()])) | ||
diff --git a/bitbake/lib/toaster/toastermain/management/commands/perf.py b/bitbake/lib/toaster/toastermain/management/commands/perf.py new file mode 100644 index 0000000000..d28f26ab16 --- /dev/null +++ b/bitbake/lib/toaster/toastermain/management/commands/perf.py | |||
@@ -0,0 +1,53 @@ | |||
1 | from django.core.management.base import BaseCommand | ||
2 | from django.test.client import Client | ||
3 | import os, sys, re | ||
4 | import requests | ||
5 | import toastermain.settings as settings | ||
6 | |||
7 | class Command(BaseCommand): | ||
8 | help = "Test the response time for all toaster urls" | ||
9 | |||
10 | def handle(self, *args, **options): | ||
11 | root_urlconf = __import__(settings.ROOT_URLCONF) | ||
12 | patterns = root_urlconf.urls.urlpatterns | ||
13 | global full_url | ||
14 | for pat in patterns: | ||
15 | if pat.__class__.__name__ == 'RegexURLResolver': | ||
16 | url_root_res = str(pat).split('^')[1].replace('>', '') | ||
17 | if 'gui' in url_root_res: | ||
18 | for url_patt in pat.url_patterns: | ||
19 | full_url = self.get_full_url(url_patt, url_root_res) | ||
20 | info = self.url_info(full_url) | ||
21 | status_code = info[0] | ||
22 | load_time = info[1] | ||
23 | print 'Trying \'' + full_url + '\', ' + str(status_code) + ', ' + str(load_time) | ||
24 | |||
25 | def get_full_url(self, url_patt, url_root_res): | ||
26 | full_url = str(url_patt).split('^')[1].replace('$>', '').replace('(?P<file_path>(?:/[', '/bin/busybox').replace('.*', '') | ||
27 | full_url = str(url_root_res + full_url) | ||
28 | full_url = re.sub('\(\?P<.*?>\\\d\+\)', '1', full_url) | ||
29 | full_url = 'http://localhost:8000/' + full_url | ||
30 | return full_url | ||
31 | |||
32 | def url_info(self, full_url): | ||
33 | client = Client() | ||
34 | info = [] | ||
35 | try: | ||
36 | resp = client.get(full_url, follow = True) | ||
37 | except Exception as e_status_code: | ||
38 | self.error('Url: %s, error: %s' % (full_url, e_status_code)) | ||
39 | resp = type('object', (), {'status_code':0, 'content': str(e_status_code)}) | ||
40 | status_code = resp.status_code | ||
41 | info.append(status_code) | ||
42 | try: | ||
43 | req = requests.get(full_url) | ||
44 | except Exception as e_load_time: | ||
45 | self.error('Url: %s, error: %s' % (full_url, e_load_time)) | ||
46 | load_time = req.elapsed | ||
47 | info.append(load_time) | ||
48 | return info | ||
49 | |||
50 | def error(self, *args): | ||
51 | for arg in args: | ||
52 | print >>sys.stderr, arg, | ||
53 | print >>sys.stderr | ||