summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--kpov_judge/tasks/dhcp_dns_predefined_ip/task.py14
1 files changed, 10 insertions, 4 deletions
diff --git a/kpov_judge/tasks/dhcp_dns_predefined_ip/task.py b/kpov_judge/tasks/dhcp_dns_predefined_ip/task.py
index 14ade9e..a7d6949 100644
--- a/kpov_judge/tasks/dhcp_dns_predefined_ip/task.py
+++ b/kpov_judge/tasks/dhcp_dns_predefined_ip/task.py
@@ -7,7 +7,7 @@ instructions = {
'si':u"""
Ustvari tri navidezne računalnike. Za enega (SimpleArbiter) uporabi sliko diska simpleArbiterGW. Na drugega (DHCP_server) postavi strežnika
DHCP in DNS. Poskrbi, da bo preostali računalnik (DHCP_client) dobil naslov, ki ga prebereš na SimpleArbiterju.
-Poskrbi, da bo DNS strežnik za HOSTNAME_X vrnil naslov {HOSTNAME_X_IP}.
+Poskrbi, da bo DNS strežnik za domeno test.net vrnil naslov {HOSTNAME_X_IP}.
DHCP_server naj za DNS strežnik uporabi {DNS_NM}.
DHCP_client naj za DNS strežnik uporabi {DNS_static}.
"""
@@ -68,7 +68,7 @@ params_meta = {
'HOSTNAME_X_IP': {'descriptions': {'si': 'Naslov HOSTNAME_X'}, 'w': False, 'public':True, 'type': 'IP', 'generated': True},
}
-def task(IP_NM, DNS_NM, IP_static, DNS_static):
+def task(IP_NM, DNS_NM, IP_static, DNS_static, HOSTNAME_X_IP):
from pexpect import pxssh
import pexpect
results = dict()
@@ -90,6 +90,8 @@ def task(IP_NM, DNS_NM, IP_static, DNS_static):
sB.prompt()
results['static_nmcli'] = sB.before
results['static_nslookup'] = sB.run('nslookup www.arnes.si')
+ # test the DNS server
+ results['NM_dns_test'] = sA.run('nslookup test 127.0.0.1')
sA.logout()
sB.logout()
return results
@@ -110,11 +112,11 @@ def task_check(results, params):
score = 0
hints = []
if results['NM_nslookup'].find('Server:\t\t{0}\r'.format(params['DNS_NM'])) > -1:
- score += 3
+ score += 2
else:
hint += ["NM DNS wrong"]
if results['static_nslookup'].find('Server:\t\t{0}\r'.format(params['DNS_static'])) > -1:
- score += 3
+ score += 2
else:
hint += ["Static DNS wrong"]
if re.search(r'e(th0|np0s3|ns3) +ethernet +connected', results['NM_nmcli']):
@@ -125,6 +127,10 @@ def task_check(results, params):
score += 2
else:
hints += ['nmcli on malibrez incorrect']
+ if results['NM_dns_test'].find('Address: {0}'.format(params['HOSTNAME_X_IP'])) > -1:
+ score += 2
+ else:
+ hints += ['DNS query wrong']
return score, hints
def prepare_disks(templates, task_params, global_params):