Patchwork [bitbake-devel,3/8] toaster: add commands to list and delete builds

login
register
mail settings
Submitter Alexandru DAMIAN
Date March 11, 2014, 3:49 p.m.
Message ID <e9a8c32512bb270cda3dee4a3ed5fd22204c24bc.1394552757.git.alexandru.damian@intel.com>
Download mbox | patch
Permalink /patch/68413/
State New
Headers show

Comments

Alexandru DAMIAN - March 11, 2014, 3:49 p.m.
From: Alexandru DAMIAN <alexandru.damian@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@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

Patch

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()]))