c99b8a3f41
There is no docker bridge on macOS. Docker document recommends using port mapping to connect to a container; but it causes a port conflict if the user is running a service that binds the same port on the host. An alternative solution is to deploy the docker environment into VirtualBox and use the host network option. Task-number: QTQAINFRA-2293 Change-Id: I05dc65c5f8b4be7a1b1874a4ec7c034cc68679ca Reviewed-by: Edward Welbourne <edward.welbourne@qt.io> Reviewed-by: Jędrzej Nowacki <jedrzej.nowacki@qt.io>
67 lines
2.5 KiB
Bash
Executable File
67 lines
2.5 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
#############################################################################
|
|
##
|
|
## Copyright (C) 2018 The Qt Company Ltd.
|
|
## Contact: https://www.qt.io/licensing/
|
|
##
|
|
## This file is part of the test suite of the Qt Toolkit.
|
|
##
|
|
## $QT_BEGIN_LICENSE:GPL$
|
|
## Commercial License Usage
|
|
## Licensees holding valid commercial Qt licenses may use this file in
|
|
## accordance with the commercial license agreement provided with the
|
|
## Software or, alternatively, in accordance with the terms contained in
|
|
## a written agreement between you and The Qt Company. For licensing terms
|
|
## and conditions see https://www.qt.io/terms-conditions. For further
|
|
## information use the contact form at https://www.qt.io/contact-us.
|
|
##
|
|
## GNU General Public License Usage
|
|
## Alternatively, this file may be used under the terms of the GNU
|
|
## General Public License version 3 or (at your option) any later version
|
|
## approved by the KDE Free Qt Foundation. The licenses are as published by
|
|
## the Free Software Foundation and appearing in the file LICENSE.GPL3
|
|
## included in the packaging of this file. Please review the following
|
|
## information to ensure the GNU General Public License requirements will
|
|
## be met: https://www.gnu.org/licenses/gpl-3.0.html.
|
|
##
|
|
## $QT_END_LICENSE$
|
|
##
|
|
#############################################################################
|
|
|
|
set -ex
|
|
|
|
# package vsftpd
|
|
|
|
# add users
|
|
usermod -d "/home/$USER/ftp/" ftp #existing user
|
|
useradd -d "/home/$USER/ftp" -s /bin/bash ftptest; echo "ftptest:$PASS" | chpasswd
|
|
|
|
# install configurations and test data
|
|
cp $TESTDATA/vsftpd.{conf,user_list} /etc/
|
|
|
|
# Resolve error message "vsftpd failed - probably invalid config" during boot
|
|
command='start-stop-daemon --start --background -m --oknodo --pidfile /var/run/vsftpd/vsftpd.pid'
|
|
command+=' --exec ${DAEMON}'
|
|
sed -i "s,$command.*$,$command; sleep 10," /etc/init.d/vsftpd
|
|
|
|
# Populate the FTP sites:
|
|
su $USER -c "cp -r $TESTDATA/ftp ~/ftp"
|
|
ln -s /home/$USER/ftp /var/ftp
|
|
|
|
# tst_QNetworkReply::getFromFtp_data()
|
|
su $USER -c "mkdir -p ~/ftp/qtest/"
|
|
su $USER -c "cp rfc3252.txt ~/ftp/qtest/"; rm rfc3252.txt
|
|
|
|
# Duplicate rfc3252.txt 20 times for bigfile tests:
|
|
su $USER -c "seq 20 | xargs -i cat ~/ftp/qtest/rfc3252.txt >> ~/ftp/qtest/bigfile"
|
|
|
|
# tst_QNetworkReply::getErrors_data(), testdata with special permissions
|
|
su $USER -c "chmod 0600 ~/ftp/pub/file-not-readable.txt"
|
|
|
|
# Shared FTP folder (sticky bit)
|
|
su $USER -c "mkdir -p -m 1777 ~/ftp/qtest/upload" # FTP incoming dir
|
|
|
|
# enable service with installed configurations
|
|
service vsftpd restart
|