Utility functions for building test images

These functions allow images to be built using diskimage-builder which
contain packages built from local project checkouts:
build_dib_pip_repo() - Builds a local pip repo from local projects and configures
                       apache to serve it
disk_image_create_upload() - Creates and uploads a diskimage-builder built image

The unused function lib/heat disk_image_create has been deleted.

Change-Id: Ia75c7c35bfd48dbe6ae3cb9c3241de0b598cbf84
This commit is contained in:
Steve Baker 2014-05-27 12:24:40 +12:00
parent 89a263bc41
commit da786b2fd9
3 changed files with 97 additions and 15 deletions

View File

@ -0,0 +1,15 @@
Listen %DIB_PIP_REPO_PORT%
<VirtualHost *:%DIB_PIP_REPO_PORT%>
DocumentRoot %DIB_PIP_REPO%
<Directory %DIB_PIP_REPO%>
DirectoryIndex index.html
Require all granted
Order allow,deny
allow from all
</Directory>
ErrorLog /var/log/%APACHE_NAME%/dib_pip_repo_error.log
LogLevel warn
CustomLog /var/log/%APACHE_NAME%/dib_pip_repo_access.log combined
</VirtualHost>

82
lib/dib
View File

@ -21,6 +21,8 @@ set +o xtrace
DIB_DIR=$DEST/diskimage-builder DIB_DIR=$DEST/diskimage-builder
TIE_DIR=$DEST/tripleo-image-elements TIE_DIR=$DEST/tripleo-image-elements
DIB_IMAGE_CACHE=$DATA_DIR/diskimage-builder/image-create DIB_IMAGE_CACHE=$DATA_DIR/diskimage-builder/image-create
DIB_PIP_REPO=$DATA_DIR/diskimage-builder/pip-repo
DIB_PIP_REPO_PORT=${DIB_PIP_REPO_PORT:-8899}
OCC_DIR=$DEST/os-collect-config OCC_DIR=$DEST/os-collect-config
ORC_DIR=$DEST/os-refresh-config ORC_DIR=$DEST/os-refresh-config
OAC_DIR=$DEST/os-apply-config OAC_DIR=$DEST/os-apply-config
@ -42,6 +44,86 @@ function install_dib {
mkdir -p $DIB_IMAGE_CACHE mkdir -p $DIB_IMAGE_CACHE
} }
# build_dib_pip_repo() - Builds a local pip repo from local projects
function build_dib_pip_repo {
local project_dirs=$1
local projpath proj package
rm -rf $DIB_PIP_REPO
mkdir -p $DIB_PIP_REPO
echo "<html><body>" > $DIB_PIP_REPO/index.html
for projpath in $project_dirs; do
proj=$(basename $projpath)
mkdir -p $DIB_PIP_REPO/$proj
pushd $projpath
rm -rf dist
python setup.py sdist
pushd dist
package=$(ls *)
mv $package $DIB_PIP_REPO/$proj/$package
popd
echo "<html><body><a href=\"$package\">$package</a></body></html>" > $DIB_PIP_REPO/$proj/index.html
echo "<a href=\"$proj\">$proj</a><br/>" >> $DIB_PIP_REPO/index.html
popd
done
echo "</body></html>" >> $DIB_PIP_REPO/index.html
local dib_pip_repo_apache_conf=$(apache_site_config_for dib_pip_repo)
sudo cp $FILES/apache-dib-pip-repo.template $dib_pip_repo_apache_conf
sudo sed -e "
s|%DIB_PIP_REPO%|$DIB_PIP_REPO|g;
s|%DIB_PIP_REPO_PORT%|$DIB_PIP_REPO_PORT|g;
s|%APACHE_NAME%|$APACHE_NAME|g;
" -i $dib_pip_repo_apache_conf
enable_apache_site dib_pip_repo
}
# disk_image_create_upload() - Creates and uploads a diskimage-builder built image
function disk_image_create_upload {
local image_name=$1
local image_elements=$2
local elements_path=$3
local image_path=$TOP_DIR/files/$image_name.qcow2
# Set the local pip repo as the primary index mirror so the
# image is built with local packages
local pypi_mirror_url=http://$SERVICE_HOST:$DIB_PIP_REPO_PORT/
local pypi_mirror_url_1
if [ -a $HOME/.pip/pip.conf ]; then
# Add the current pip.conf index-url as an extra-index-url
# in the image build
pypi_mirror_url_1=$(iniget $HOME/.pip/pip.conf global index-url)
else
# If no pip.conf, set upstream pypi as an extra mirror
# (this also sets the .pydistutils.cfg index-url)
pypi_mirror_url_1=http://pypi.python.org/simple
fi
# The disk-image-create command to run
ELEMENTS_PATH=$elements_path \
PYPI_MIRROR_URL=$pypi_mirror_url \
PYPI_MIRROR_URL_1=$pypi_mirror_url_1 \
disk-image-create -a amd64 $image_elements \
--image-cache $DIB_IMAGE_CACHE \
-o $image_path
local token=$(keystone token-get | grep ' id ' | get_field 2)
die_if_not_set $LINENO token "Keystone fail to get token"
glance --os-auth-token $token --os-image-url http://$GLANCE_HOSTPORT \
image-create --name $image_name --is-public True \
--container-format=bare --disk-format qcow2 \
< $image_path
}
# Restore xtrace # Restore xtrace
$XTRACE $XTRACE

View File

@ -204,21 +204,6 @@ function stop_heat {
done done
} }
function disk_image_create {
local elements_path=$1
local elements=$2
local arch=$3
local output=$TOP_DIR/files/$4
if [[ -f "$output.qcow2" ]]; then
echo "Image file already exists: $output_file"
else
ELEMENTS_PATH=$elements_path disk-image-create \
$elements -a $arch -o $output
fi
# upload with fake URL so that image in $TOP_DIR/files is used
upload_image "http://localhost/$output.qcow2" $TOKEN
}
# create_heat_accounts() - Set up common required heat accounts # create_heat_accounts() - Set up common required heat accounts
function create_heat_accounts { function create_heat_accounts {
# migrated from files/keystone_data.sh # migrated from files/keystone_data.sh