[bitbake-devel] [PATCH 3/8] toaster: add commands to list and delete builds
Alex DAMIAN
alexandru.damian at intel.com
Tue Mar 11 15:49:47 UTC 2014
From: Alexandru DAMIAN <alexandru.damian at intel.com>
We add Django commands for the manage.py to manage the database
content.
The two commands added are:
* buildslist - produces a list of current builds
* builddelete - deletes a build and all associated data from the database
Signed-off-by: Alexandru DAMIAN <alexandru.damian at intel.com>
---
lib/toaster/toastermain/management/__init__.py | 0
.../toastermain/management/commands/__init__.py | 0
.../toastermain/management/commands/builddelete.py | 33 ++++++++++++++++++++++
.../toastermain/management/commands/buildslist.py | 13 +++++++++
4 files changed, 46 insertions(+)
create mode 100644 lib/toaster/toastermain/management/__init__.py
create mode 100644 lib/toaster/toastermain/management/commands/__init__.py
create mode 100644 lib/toaster/toastermain/management/commands/builddelete.py
create mode 100644 lib/toaster/toastermain/management/commands/buildslist.py
diff --git a/lib/toaster/toastermain/management/__init__.py b/lib/toaster/toastermain/management/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/lib/toaster/toastermain/management/commands/__init__.py b/lib/toaster/toastermain/management/commands/__init__.py
new file mode 100644
index 0000000..e69de29
diff --git a/lib/toaster/toastermain/management/commands/builddelete.py b/lib/toaster/toastermain/management/commands/builddelete.py
new file mode 100644
index 0000000..5cec436
--- /dev/null
+++ b/lib/toaster/toastermain/management/commands/builddelete.py
@@ -0,0 +1,33 @@
+from django.core.management.base import BaseCommand, CommandError
+from orm.models import Build
+import os
+
+
+
+class Command(BaseCommand):
+ args = "buildId"
+ help = "Deletes selected build"
+
+ def handle(self, buildId, *args, **options):
+ b = Build.objects.get(pk = buildId)
+ # theoretically, just b.delete() would suffice
+ # however SQLite runs into problems when you try to
+ # delete too many rows at once, so we delete some direct
+ # relationships from Build manually.
+
+ for t in b.target_set.all():
+ t.delete()
+ for t in b.task_build.all():
+ t.delete()
+ for p in b.package_set.all():
+ p.delete()
+ for lv in b.layer_version_build.all():
+ lv.delete()
+ for v in b.variable_build.all():
+ v.delete()
+ for l in b.logmessage_set.all():
+ l.delete()
+
+ # this should take care of the rest
+ b.delete()
+
diff --git a/lib/toaster/toastermain/management/commands/buildslist.py b/lib/toaster/toastermain/management/commands/buildslist.py
new file mode 100644
index 0000000..cad987f
--- /dev/null
+++ b/lib/toaster/toastermain/management/commands/buildslist.py
@@ -0,0 +1,13 @@
+from django.core.management.base import NoArgsCommand, CommandError
+from orm.models import Build
+import os
+
+
+
+class Command(NoArgsCommand):
+ args = ""
+ help = "Lists current builds"
+
+ def handle_noargs(self,**options):
+ for b in Build.objects.all():
+ print "%d: %s %s %s" % (b.pk, b.machine, b.distro, ",".join([x.target for x in b.target_set.all()]))
--
1.8.3.2
More information about the bitbake-devel
mailing list