summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlexandru DAMIAN <alexandru.damian@intel.com>2014-07-17 15:30:17 +0100
committerRichard Purdie <richard.purdie@linuxfoundation.org>2014-07-23 20:07:43 +0100
commit37d2066c83e9c29d10491f5d6f9410ce8fd6222a (patch)
tree1282c25cb67ced126085a91befeeaf291a047410
parent1b9175af3fabf12af80c8446af94078afd0832ed (diff)
downloadpoky-37d2066c83e9c29d10491f5d6f9410ce8fd6222a.tar.gz
bitbake: toaster-requirements.txt: document requirements for the python environment
Since Toaster adds a number of specific requirements managed by pip, we document these requirements in order to be able to run bitbake and toaster under virtualenv. The target here is to break the dependency on distro packages for specific python libraries. In order to start bitbake/Toaster in a distro-independent manner, we use virtualenv and pip. We add venv to the .gitignore list to make room for the virtualenv deployment in this directory. Use this command sequence to setup the virtualenv: $ virtualenv venv $ . venv/bin/activate $ cat toaster-requirements.txt | xargs pip install bitbake and Toaster will then run normally under virtualenv. We also fix bugs related to toaster starting in managed mode through this script: * toaster will not use bldcontrol application in interactive mode * a proper message will be displayed if toaster detects a managed start request in a build environment (Bitbake rev: b5789c7ea7e6d1a4b67ec60fc0e4233ec543ba3a) Signed-off-by: Alexandru DAMIAN <alexandru.damian@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rwxr-xr-xbitbake/bin/toaster19
-rw-r--r--bitbake/toaster-requirements.txt4
2 files changed, 15 insertions, 8 deletions
diff --git a/bitbake/bin/toaster b/bitbake/bin/toaster
index 1f90362b1f..ce16de6c3b 100755
--- a/bitbake/bin/toaster
+++ b/bitbake/bin/toaster
@@ -63,9 +63,11 @@ function webserverStartAll()
63 retval=0 63 retval=0
64 python $BBBASEDIR/lib/toaster/manage.py migrate orm || retval=1 64 python $BBBASEDIR/lib/toaster/manage.py migrate orm || retval=1
65 fi 65 fi
66 python $BBBASEDIR/lib/toaster/manage.py migrate bldcontrol || retval=1 66 if [ "x$TOASTER_MANAGED" == "x1" ]; then
67 python $BBBASEDIR/lib/toaster/manage.py checksettings || retval=1 67 python $BBBASEDIR/lib/toaster/manage.py migrate bldcontrol || retval=1
68 68 python $BBBASEDIR/lib/toaster/manage.py checksettings || retval=1
69 fi
70 echo "Starting webserver"
69 if [ $retval -eq 0 ]; then 71 if [ $retval -eq 0 ]; then
70 python $BBBASEDIR/lib/toaster/manage.py runserver 0.0.0.0:8000 </dev/null >${BUILDDIR}/toaster_web.log 2>&1 & echo $! >${BUILDDIR}/.toastermain.pid 72 python $BBBASEDIR/lib/toaster/manage.py runserver 0.0.0.0:8000 </dev/null >${BUILDDIR}/toaster_web.log 2>&1 & echo $! >${BUILDDIR}/.toastermain.pid
71 sleep 1 73 sleep 1
@@ -128,8 +130,8 @@ if [ -z "$ZSH_NAME" ] && [ `basename \"$0\"` = `basename \"$BASH_SOURCE\"` ]; th
128 # Start just the web server, point the web browser to the interface, and start any Django services. 130 # Start just the web server, point the web browser to the interface, and start any Django services.
129 131
130 if [ -n "$BUILDDIR" ]; then 132 if [ -n "$BUILDDIR" ]; then
131 echo "Error: build/ directory detected. Standalone Toaster will not start in a build environment." 1>&2; 133 echo -e "Error: build/ directory detected. Toaster will not start in managed mode if a build environment is detected.\nUse a clean terminal to start Toaster." 1>&2;
132 return 1; 134 exit 1;
133 fi 135 fi
134 136
135 # Define a fake builddir where only the pid files are actually created. No real builds will take place here. 137 # Define a fake builddir where only the pid files are actually created. No real builds will take place here.
@@ -140,6 +142,7 @@ if [ -z "$ZSH_NAME" ] && [ `basename \"$0\"` = `basename \"$BASH_SOURCE\"` ]; th
140 webserverKillAll 142 webserverKillAll
141 RUNNING=0 143 RUNNING=0
142 } 144 }
145 TOASTER_MANAGED=1
143 export TOASTER_MANAGED=1 146 export TOASTER_MANAGED=1
144 webserverStartAll || (echo "Fail to start the web server, stopping" 1>&2 && exit 1) 147 webserverStartAll || (echo "Fail to start the web server, stopping" 1>&2 && exit 1)
145 xdg-open http://0.0.0.0:8000/ >/dev/null 2>&1 & 148 xdg-open http://0.0.0.0:8000/ >/dev/null 2>&1 &
@@ -163,13 +166,13 @@ fi
163 166
164# Verify prerequisites 167# Verify prerequisites
165 168
166if ! echo "import django; print (1,5) == django.VERSION[0:2]" | python 2>/dev/null | grep True >/dev/null; then 169if ! echo "import django; print (1,) == django.VERSION[0:1] and django.VERSION[1:2][0] in (5,6)" | python 2>/dev/null | grep True >/dev/null; then
167 echo -e "This program needs Django 1.5. Please install with\n\nsudo pip install django==1.5" 170 echo -e "This program needs Django 1.5 or 1.6. Please install with\n\npip install django==1.6"
168 return 2 171 return 2
169fi 172fi
170 173
171if ! echo "import south; print [0,8,4] == map(int,south.__version__.split(\".\"))" | python 2>/dev/null | grep True >/dev/null; then 174if ! echo "import south; print [0,8,4] == map(int,south.__version__.split(\".\"))" | python 2>/dev/null | grep True >/dev/null; then
172 echo -e "This program needs South 0.8.4. Please install with\n\nsudo pip install south==0.8.4" 175 echo -e "This program needs South 0.8.4. Please install with\n\npip install south==0.8.4"
173 return 2 176 return 2
174fi 177fi
175 178
diff --git a/bitbake/toaster-requirements.txt b/bitbake/toaster-requirements.txt
new file mode 100644
index 0000000000..19b5293722
--- /dev/null
+++ b/bitbake/toaster-requirements.txt
@@ -0,0 +1,4 @@
1Django==1.6
2South==0.8.4
3argparse==1.2.1
4wsgiref==0.1.2