mirror of
https://github.com/pi-hole/pi-hole.git
synced 2025-04-04 06:30:19 +00:00
revert "set permission for /var/cache if it did not exist before" and make lighttpd start work
Signed-off-by: pvogt09 <50047961+pvogt09@users.noreply.github.com>
This commit is contained in:
parent
45fe918516
commit
e82b136b8a
3 changed files with 46 additions and 15 deletions
|
@ -1431,13 +1431,7 @@ installConfigs() {
|
||||||
# Make the directories if they do not exist and set the owners
|
# Make the directories if they do not exist and set the owners
|
||||||
mkdir -p /run/lighttpd
|
mkdir -p /run/lighttpd
|
||||||
chown ${LIGHTTPD_USER}:${LIGHTTPD_GROUP} /run/lighttpd
|
chown ${LIGHTTPD_USER}:${LIGHTTPD_GROUP} /run/lighttpd
|
||||||
test -d /var/cache
|
|
||||||
local varcache=$?
|
|
||||||
mkdir -p /var/cache/lighttpd/compress
|
mkdir -p /var/cache/lighttpd/compress
|
||||||
if [[ ! "${varcache}" -eq 0 ]]; then
|
|
||||||
chmod a+rx /var/cache
|
|
||||||
fi
|
|
||||||
chown ${LIGHTTPD_USER}:${LIGHTTPD_GROUP} /var/cache/lighttpd
|
|
||||||
chown ${LIGHTTPD_USER}:${LIGHTTPD_GROUP} /var/cache/lighttpd/compress
|
chown ${LIGHTTPD_USER}:${LIGHTTPD_GROUP} /var/cache/lighttpd/compress
|
||||||
mkdir -p /var/cache/lighttpd/uploads
|
mkdir -p /var/cache/lighttpd/uploads
|
||||||
chown ${LIGHTTPD_USER}:${LIGHTTPD_GROUP} /var/cache/lighttpd/uploads
|
chown ${LIGHTTPD_USER}:${LIGHTTPD_GROUP} /var/cache/lighttpd/uploads
|
||||||
|
|
|
@ -121,6 +121,33 @@ def mock_command(script, args, container):
|
||||||
scriptlog=script))
|
scriptlog=script))
|
||||||
|
|
||||||
|
|
||||||
|
def mock_command_run(script, args, container):
|
||||||
|
'''
|
||||||
|
Allows for setup of commands we don't really want to have to run for real
|
||||||
|
in unit tests
|
||||||
|
'''
|
||||||
|
full_script_path = '/usr/local/bin/{}'.format(script)
|
||||||
|
mock_script = dedent('''\
|
||||||
|
#!/bin/bash -e
|
||||||
|
echo "\$0 \$@" >> /var/log/{script}
|
||||||
|
case "\$1 \$2" in'''.format(script=script))
|
||||||
|
for k, v in args.items():
|
||||||
|
case = dedent('''
|
||||||
|
\"{arg}\")
|
||||||
|
echo {res}
|
||||||
|
exit {retcode}
|
||||||
|
;;'''.format(arg=k, res=v[0], retcode=v[1]))
|
||||||
|
mock_script += case
|
||||||
|
mock_script += dedent('''
|
||||||
|
esac''')
|
||||||
|
container.run('''
|
||||||
|
cat <<EOF> {script}\n{content}\nEOF
|
||||||
|
chmod +x {script}
|
||||||
|
rm -f /var/log/{scriptlog}'''.format(script=full_script_path,
|
||||||
|
content=mock_script,
|
||||||
|
scriptlog=script))
|
||||||
|
|
||||||
|
|
||||||
def mock_command_2(script, args, container):
|
def mock_command_2(script, args, container):
|
||||||
'''
|
'''
|
||||||
Allows for setup of commands we don't really want to have to run for real
|
Allows for setup of commands we don't really want to have to run for real
|
||||||
|
@ -147,7 +174,6 @@ def mock_command_2(script, args, container):
|
||||||
content=mock_script,
|
content=mock_script,
|
||||||
scriptlog=script))
|
scriptlog=script))
|
||||||
|
|
||||||
|
|
||||||
def run_script(Pihole, script):
|
def run_script(Pihole, script):
|
||||||
result = Pihole.run(script)
|
result = Pihole.run(script)
|
||||||
assert result.rc == 0
|
assert result.rc == 0
|
||||||
|
|
|
@ -7,6 +7,7 @@ from .conftest import (
|
||||||
info_box,
|
info_box,
|
||||||
cross_box,
|
cross_box,
|
||||||
mock_command,
|
mock_command,
|
||||||
|
mock_command_run,
|
||||||
mock_command_2,
|
mock_command_2,
|
||||||
run_script
|
run_script
|
||||||
)
|
)
|
||||||
|
@ -421,7 +422,7 @@ def test_installPihole_fresh_install_readableFiles(Pihole):
|
||||||
actual_rc = Pihole.run(check_pihole).rc
|
actual_rc = Pihole.run(check_pihole).rc
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize("test_webpage", [False])
|
@pytest.mark.parametrize("test_webpage", [True])
|
||||||
def test_installPihole_fresh_install_readableBlockpage(Pihole, test_webpage):
|
def test_installPihole_fresh_install_readableBlockpage(Pihole, test_webpage):
|
||||||
'''
|
'''
|
||||||
confirms all web page assets from Core repo are readable
|
confirms all web page assets from Core repo are readable
|
||||||
|
@ -429,11 +430,14 @@ def test_installPihole_fresh_install_readableBlockpage(Pihole, test_webpage):
|
||||||
'''
|
'''
|
||||||
# TODO: also add IP address from setupVars?
|
# TODO: also add IP address from setupVars?
|
||||||
# TODO: pi.hole can not be resolved because of some error in FTL or resolved
|
# TODO: pi.hole can not be resolved because of some error in FTL or resolved
|
||||||
piholeWebpage = ["http://127.0.0.1/admin", "http://pi.hole/admin"]
|
piholeWebpage = [
|
||||||
|
"http://127.0.0.1/admin",
|
||||||
|
"http://pi.hole/admin"
|
||||||
|
]
|
||||||
# Whiptail dialog returns Cancel for user prompt
|
# Whiptail dialog returns Cancel for user prompt
|
||||||
mock_command('whiptail', {'*': ('', '0')}, Pihole)
|
mock_command('whiptail', {'*': ('', '0')}, Pihole)
|
||||||
# mock systemctl to start lighttpd and FTL
|
# mock systemctl to start lighttpd and FTL
|
||||||
ligthttpdcommand = dedent(r'''\"
|
ligthttpdcommand = dedent(r'''\"\"
|
||||||
echo 'starting lighttpd with {}'
|
echo 'starting lighttpd with {}'
|
||||||
if [ command -v "apt-get" >/dev/null 2>&1 ]; then
|
if [ command -v "apt-get" >/dev/null 2>&1 ]; then
|
||||||
LIGHTTPD_USER="www-data"
|
LIGHTTPD_USER="www-data"
|
||||||
|
@ -444,8 +448,10 @@ def test_installPihole_fresh_install_readableBlockpage(Pihole, test_webpage):
|
||||||
fi
|
fi
|
||||||
mkdir -p "{run}"
|
mkdir -p "{run}"
|
||||||
chown {usergroup} "{run}"
|
chown {usergroup} "{run}"
|
||||||
mkdir -p "{compress}"
|
mkdir -p "{cache}"
|
||||||
|
chown {usergroup} "/var/cache"
|
||||||
chown {usergroup} "{cache}"
|
chown {usergroup} "{cache}"
|
||||||
|
mkdir -p "{compress}"
|
||||||
chown {usergroup} "{compress}"
|
chown {usergroup} "{compress}"
|
||||||
mkdir -p "{uploads}"
|
mkdir -p "{uploads}"
|
||||||
chown {usergroup} "{uploads}"
|
chown {usergroup} "{uploads}"
|
||||||
|
@ -461,7 +467,7 @@ def test_installPihole_fresh_install_readableBlockpage(Pihole, test_webpage):
|
||||||
find "{uploads}" -type f -exec chmod 0666 {chmodarg} \;;
|
find "{uploads}" -type f -exec chmod 0666 {chmodarg} \;;
|
||||||
/usr/sbin/lighttpd -tt -f '{config}'
|
/usr/sbin/lighttpd -tt -f '{config}'
|
||||||
/usr/sbin/lighttpd -f '{config}'
|
/usr/sbin/lighttpd -f '{config}'
|
||||||
echo \"'''.format(
|
echo \"\"'''.format(
|
||||||
'{}',
|
'{}',
|
||||||
usergroup='${{LIGHTTPD_USER}}:${{LIGHTTPD_GROUP}}',
|
usergroup='${{LIGHTTPD_USER}}:${{LIGHTTPD_GROUP}}',
|
||||||
chmodarg='{{}}',
|
chmodarg='{{}}',
|
||||||
|
@ -472,10 +478,10 @@ def test_installPihole_fresh_install_readableBlockpage(Pihole, test_webpage):
|
||||||
compress='/var/cache/lighttpd/compress'
|
compress='/var/cache/lighttpd/compress'
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
FTLcommand = dedent('''\"
|
FTLcommand = dedent('''\"\"
|
||||||
/etc/init.d/pihole-FTL restart
|
/etc/init.d/pihole-FTL restart
|
||||||
echo \"''')
|
echo \"\"''')
|
||||||
mock_command_2(
|
mock_command_run(
|
||||||
'systemctl',
|
'systemctl',
|
||||||
{
|
{
|
||||||
'enable lighttpd': (
|
'enable lighttpd': (
|
||||||
|
@ -517,6 +523,11 @@ def test_installPihole_fresh_install_readableBlockpage(Pihole, test_webpage):
|
||||||
setup_var_file += "INSTALL_WEB_INTERFACE=true\n"
|
setup_var_file += "INSTALL_WEB_INTERFACE=true\n"
|
||||||
setup_var_file += "EOF\n"
|
setup_var_file += "EOF\n"
|
||||||
Pihole.run(setup_var_file)
|
Pihole.run(setup_var_file)
|
||||||
|
# TODO: set in dependance of currently build branch
|
||||||
|
b = Pihole.run('mkdir -p /etc/pihole && echo "development" > /etc/pihole/ftlbranch');
|
||||||
|
assert 0 == b.rc
|
||||||
|
b = Pihole.run('cat /etc/pihole/ftlbranch');
|
||||||
|
print(b.stdout)
|
||||||
installWeb = Pihole.run('''
|
installWeb = Pihole.run('''
|
||||||
export TERM=xterm
|
export TERM=xterm
|
||||||
export DEBIAN_FRONTEND=noninteractive
|
export DEBIAN_FRONTEND=noninteractive
|
||||||
|
|
Loading…
Add table
Reference in a new issue