From 297d4eec57ae6be66b4bc28a274744c0516655a5 Mon Sep 17 00:00:00 2001 From: Dan Schaper Date: Sat, 28 Jan 2017 15:44:31 -0800 Subject: [PATCH 1/8] Start test templates. --- automated install/basic-install.sh | 5 +++-- test/test_automated_install.py | 9 +++++++++ 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/automated install/basic-install.sh b/automated install/basic-install.sh index 9fed0bca..1b643c18 100755 --- a/automated install/basic-install.sh +++ b/automated install/basic-install.sh @@ -701,8 +701,9 @@ update_pacakge_cache() { echo ":::" echo -n "::: Updating local cache of available packages..." - ${UPDATE_PKG_CACHE} &> /dev/null - echo " done!" + if ${UPDATE_PKG_CACHE}; then + echo " done!" + fi } notify_package_updates_available() { diff --git a/test/test_automated_install.py b/test/test_automated_install.py index f8e2ec3d..203c7521 100644 --- a/test/test_automated_install.py +++ b/test/test_automated_install.py @@ -274,6 +274,15 @@ def test_installPiholeWeb_already_populated_no_errors(Pihole): assert 'index.js' in web_directory assert 'blockingpage.css' in web_directory +def test_update_package_cache_success_no_errors(Pihole): + ''' confirms package cache was updated without any errors''' + updateCache = Pihole.run(''' + source /opt/pihole/basick-install.sh + update_pacakge_cache + ''') + assert 'Updating local cache of available packages...' in updateCache.stdout + assert 'done!' in updateCache.stdout + # Helper functions def mock_command(script, args, container): ''' Allows for setup of commands we don't really want to have to run for real in unit tests ''' From 153a9d8ac71c51bdf4d211d2117af6fb123fa06d Mon Sep 17 00:00:00 2001 From: Dan Schaper Date: Sat, 28 Jan 2017 15:45:25 -0800 Subject: [PATCH 2/8] Start test templates. --- test/test_automated_install.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/test_automated_install.py b/test/test_automated_install.py index 203c7521..7f287c8f 100644 --- a/test/test_automated_install.py +++ b/test/test_automated_install.py @@ -277,7 +277,7 @@ def test_installPiholeWeb_already_populated_no_errors(Pihole): def test_update_package_cache_success_no_errors(Pihole): ''' confirms package cache was updated without any errors''' updateCache = Pihole.run(''' - source /opt/pihole/basick-install.sh + source /opt/pihole/basic-install.sh update_pacakge_cache ''') assert 'Updating local cache of available packages...' in updateCache.stdout From 96c59fada44ef451a979d41fe1df8c89d8d1ac81 Mon Sep 17 00:00:00 2001 From: Dan Schaper Date: Sat, 28 Jan 2017 15:47:27 -0800 Subject: [PATCH 3/8] Spelling check. --- automated install/basic-install.sh | 4 ++-- test/test_automated_install.py | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/automated install/basic-install.sh b/automated install/basic-install.sh index 1b643c18..003cd312 100755 --- a/automated install/basic-install.sh +++ b/automated install/basic-install.sh @@ -692,7 +692,7 @@ enable_service() { echo " done." } -update_pacakge_cache() { +update_package_cache() { #Running apt-get update/upgrade with minimal output can cause some issues with #requiring user input (e.g password for phpmyadmin see #218) @@ -1128,7 +1128,7 @@ main() { fi # Update package cache - update_pacakge_cache + update_package_cache # Notify user of package availability notify_package_updates_available diff --git a/test/test_automated_install.py b/test/test_automated_install.py index 7f287c8f..c502aef6 100644 --- a/test/test_automated_install.py +++ b/test/test_automated_install.py @@ -278,7 +278,7 @@ def test_update_package_cache_success_no_errors(Pihole): ''' confirms package cache was updated without any errors''' updateCache = Pihole.run(''' source /opt/pihole/basic-install.sh - update_pacakge_cache + update_package_cache ''') assert 'Updating local cache of available packages...' in updateCache.stdout assert 'done!' in updateCache.stdout From f65a9dbfd281b3f7e37e3c63d50a06c52bce3929 Mon Sep 17 00:00:00 2001 From: Dan Schaper Date: Sat, 28 Jan 2017 15:49:28 -0800 Subject: [PATCH 4/8] Test for failure. --- test/test_automated_install.py | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/test/test_automated_install.py b/test/test_automated_install.py index c502aef6..7096ad91 100644 --- a/test/test_automated_install.py +++ b/test/test_automated_install.py @@ -283,6 +283,16 @@ def test_update_package_cache_success_no_errors(Pihole): assert 'Updating local cache of available packages...' in updateCache.stdout assert 'done!' in updateCache.stdout +def test_update_package_cache_failure_no_errors(Pihole): + ''' confirms package cache was updated without any errors''' + mock_command(apt-get, {'*':('', '1')}, Pihole) + updateCache = Pihole.run(''' + source /opt/pihole/basic-install.sh + update_package_cache + ''') + assert 'Updating local cache of available packages...' in updateCache.stdout + assert 'done!' not in updateCache.stdout + # Helper functions def mock_command(script, args, container): ''' Allows for setup of commands we don't really want to have to run for real in unit tests ''' From f9cfed5aff68a53a062c225720bc3534d813d0f5 Mon Sep 17 00:00:00 2001 From: Dan Schaper Date: Sat, 28 Jan 2017 15:56:43 -0800 Subject: [PATCH 5/8] Test for failure. --- test/test_automated_install.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/test_automated_install.py b/test/test_automated_install.py index 7096ad91..4ab6e3a3 100644 --- a/test/test_automated_install.py +++ b/test/test_automated_install.py @@ -285,7 +285,7 @@ def test_update_package_cache_success_no_errors(Pihole): def test_update_package_cache_failure_no_errors(Pihole): ''' confirms package cache was updated without any errors''' - mock_command(apt-get, {'*':('', '1')}, Pihole) + mock_command('apt-get', {'*':('', '1')}, Pihole) updateCache = Pihole.run(''' source /opt/pihole/basic-install.sh update_package_cache From a7130e6530ac4fbf4b5649ef5aff7be21859418f Mon Sep 17 00:00:00 2001 From: Dan Schaper Date: Sat, 28 Jan 2017 16:03:48 -0800 Subject: [PATCH 6/8] Eval variable. (Not a fan.) --- automated install/basic-install.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/automated install/basic-install.sh b/automated install/basic-install.sh index 003cd312..9245ff81 100755 --- a/automated install/basic-install.sh +++ b/automated install/basic-install.sh @@ -701,7 +701,7 @@ update_package_cache() { echo ":::" echo -n "::: Updating local cache of available packages..." - if ${UPDATE_PKG_CACHE}; then + if eval ${UPDATE_PKG_CACHE}; then echo " done!" fi } From 737819b56e0d1cf736ac4cc8d73aa5273330f431 Mon Sep 17 00:00:00 2001 From: Dan Schaper Date: Sat, 28 Jan 2017 16:08:43 -0800 Subject: [PATCH 7/8] Populate all required variables with a distro check. --- test/test_automated_install.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/test/test_automated_install.py b/test/test_automated_install.py index 4ab6e3a3..04db4f1b 100644 --- a/test/test_automated_install.py +++ b/test/test_automated_install.py @@ -278,6 +278,7 @@ def test_update_package_cache_success_no_errors(Pihole): ''' confirms package cache was updated without any errors''' updateCache = Pihole.run(''' source /opt/pihole/basic-install.sh + distro_check update_package_cache ''') assert 'Updating local cache of available packages...' in updateCache.stdout @@ -288,6 +289,7 @@ def test_update_package_cache_failure_no_errors(Pihole): mock_command('apt-get', {'*':('', '1')}, Pihole) updateCache = Pihole.run(''' source /opt/pihole/basic-install.sh + distro_check update_package_cache ''') assert 'Updating local cache of available packages...' in updateCache.stdout From 585f8422066df137d2f288a39d2fd0ed7689ac5e Mon Sep 17 00:00:00 2001 From: Dan Schaper Date: Sat, 28 Jan 2017 16:33:40 -0800 Subject: [PATCH 8/8] Error check. --- automated install/basic-install.sh | 2 ++ test/test_automated_install.py | 5 +++-- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/automated install/basic-install.sh b/automated install/basic-install.sh index 9245ff81..00635e89 100755 --- a/automated install/basic-install.sh +++ b/automated install/basic-install.sh @@ -703,6 +703,8 @@ update_package_cache() { echo -n "::: Updating local cache of available packages..." if eval ${UPDATE_PKG_CACHE}; then echo " done!" + else + echo -n "\n!!! ERROR - Unable to update package cache. Please try \"${UPDATE_PKG_CACHE}\"" fi } diff --git a/test/test_automated_install.py b/test/test_automated_install.py index 04db4f1b..29bb56d2 100644 --- a/test/test_automated_install.py +++ b/test/test_automated_install.py @@ -285,14 +285,15 @@ def test_update_package_cache_success_no_errors(Pihole): assert 'done!' in updateCache.stdout def test_update_package_cache_failure_no_errors(Pihole): - ''' confirms package cache was updated without any errors''' - mock_command('apt-get', {'*':('', '1')}, Pihole) + ''' confirms package cache was not updated''' + mock_command('apt-get', {'update':('', '1')}, Pihole) updateCache = Pihole.run(''' source /opt/pihole/basic-install.sh distro_check update_package_cache ''') assert 'Updating local cache of available packages...' in updateCache.stdout + assert 'ERROR' in updateCache.stdout assert 'done!' not in updateCache.stdout # Helper functions