@ -7,10 +7,8 @@
# (at your option) any later version.
# (at your option) any later version.
import apt_pkg
import apt_pkg
import operator
import os
import os
import sys
import sys
import subprocess
import fileinput
import fileinput
import unittest
import unittest
import json
import json
@ -18,7 +16,6 @@ import json
PROJECT_DIR = os . path . dirname ( os . path . dirname ( os . path . abspath ( __file__ ) ) )
PROJECT_DIR = os . path . dirname ( os . path . dirname ( os . path . abspath ( __file__ ) ) )
sys . path . insert ( 0 , PROJECT_DIR )
sys . path . insert ( 0 , PROJECT_DIR )
from autopkgtest import ADT_EXCUSES_LABELS
from tests import TestBase , mock_swift
from tests import TestBase , mock_swift
NOT_CONSIDERED = False
NOT_CONSIDERED = False
@ -46,16 +43,6 @@ class TestAutoPkgTest(TestBase):
else :
else :
sys . stdout . write ( line )
sys . stdout . write ( line )
# fake adt-britney script; necessary until we drop that code
self . adt_britney = os . path . join (
self . data . home , ' auto-package-testing ' , ' jenkins ' , ' adt-britney ' )
os . makedirs ( os . path . dirname ( self . adt_britney ) )
with open ( self . adt_britney , ' w ' ) as f :
f . write ( ''' #!/bin/sh -e
touch $ HOME / proposed - migration / autopkgtest / work / adt . request . series
echo " $@ " >> / % s / adt - britney . log ''' % s elf.data.path)
os . chmod ( self . adt_britney , 0o755 )
# add a bunch of packages to testing to avoid repetition
# add a bunch of packages to testing to avoid repetition
self . data . add ( ' libc6 ' , False )
self . data . add ( ' libc6 ' , False )
self . data . add ( ' libgreen1 ' , False , { ' Source ' : ' green ' ,
self . data . add ( ' libgreen1 ' , False , { ' Source ' : ' green ' ,
@ -89,7 +76,8 @@ echo "$@" >> /%s/adt-britney.log ''' % self.data.path)
( excuses , out ) = self . run_britney ( )
( excuses , out ) = self . run_britney ( )
self . swift . stop ( )
self . swift . stop ( )
#print('-------\nexcuses: %s\n-----' % excuses)
if ' SHOW_EXCUSES ' in os . environ :
print ( ' ------- \n excuses: %s \n ----- ' % excuses )
if ' SHOW_OUTPUT ' in os . environ :
if ' SHOW_OUTPUT ' in os . environ :
print ( ' ------- \n out: %s \n ----- ' % out )
print ( ' ------- \n out: %s \n ----- ' % out )
if considered :
if considered :
@ -120,14 +108,27 @@ echo "$@" >> /%s/adt-britney.log ''' % self.data.path)
return out
return out
def test_no_request_for_uninstallable ( self ) :
''' Does not request a test for an uninstallable package '''
self . do_test (
# uninstallable unstable version
[ ( ' lightgreen ' , { ' Version ' : ' 1.1~beta ' , ' Depends ' : ' libc6 (>= 0.9), libgreen1 (>= 2) ' } , ' autopkgtest ' ) ] ,
NOT_CONSIDERED ,
[ r ' \ blightgreen \ b.*>1</a> to .*>1.1~beta< ' ,
' lightgreen/amd64 unsatisfiable Depends: libgreen1 \ (>= 2 \ ) ' ] ,
# autopkgtest should not be triggered for uninstallable pkg
[ ' autopkgtest ' ] )
self . assertEqual ( self . pending_requests , ' ' )
self . assertEqual ( self . amqp_requests , set ( ) )
def test_multi_rdepends_with_tests_all_running ( self ) :
def test_multi_rdepends_with_tests_all_running ( self ) :
''' Multiple reverse dependencies with tests (all running) '''
''' Multiple reverse dependencies with tests (all running) '''
self . do_test (
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
# FIXME: while we only submit requests through AMQP, but don't consider
NOT_CONSIDERED ,
# their results, we don't expect this to hold back stuff.
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for green 2: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for green 2: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*in progress.*i386.*in progress ' ,
@ -153,7 +154,7 @@ lightgreen 1 i386 green 2
self . assertEqual ( self . pending_requests , expected_pending )
self . assertEqual ( self . pending_requests , expected_pending )
# if we run britney again this should *not* trigger any new tests
# if we run britney again this should *not* trigger any new tests
self . do_test ( [ ] , VALID_CANDIDATE , [ r ' \ bgreen \ b.*>1</a> to .*>2< ' ] )
self . do_test ( [ ] , NOT_CONSIDERED , [ r ' \ bgreen \ b.*>1</a> to .*>2< ' ] )
self . assertEqual ( self . amqp_requests , set ( ) )
self . assertEqual ( self . amqp_requests , set ( ) )
# but the set of pending tests doesn't change
# but the set of pending tests doesn't change
self . assertEqual ( self . pending_requests , expected_pending )
self . assertEqual ( self . pending_requests , expected_pending )
@ -164,9 +165,7 @@ lightgreen 1 i386 green 2
# first run requests tests and marks them as pending
# first run requests tests and marks them as pending
self . do_test (
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
# FIXME: while we only submit requests through AMQP, but don't consider
NOT_CONSIDERED ,
# their results, we don't expect this to hold back stuff.
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for green 2: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for green 2: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*in progress.*i386.*in progress ' ,
@ -233,9 +232,7 @@ lightgreen 1 i386 green 2
# first run requests tests and marks them as pending
# first run requests tests and marks them as pending
self . do_test (
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
# FIXME: while we only submit requests through AMQP, but don't consider
NOT_CONSIDERED ,
# their results, we don't expect this to hold back stuff.
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for green 2: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for green 2: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*in progress.*i386.*in progress ' ,
@ -252,9 +249,7 @@ lightgreen 1 i386 green 2
out = self . do_test (
out = self . do_test (
[ ] ,
[ ] ,
# FIXME: while we only submit requests through AMQP, but don't consider
NOT_CONSIDERED ,
# their results, we don't expect this to hold back stuff.
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for green 2: .*amd64.*Always failed.*i386.*Pass ' ,
r ' autopkgtest for green 2: .*amd64.*Always failed.*i386.*Pass ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*Regression.*i386.*in progress ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*Regression.*i386.*in progress ' ,
@ -267,15 +262,174 @@ lightgreen 1 i386 green 2
self . assertIn ( ' darkgreen 1 amd64 green 2 ' , self . pending_requests )
self . assertIn ( ' darkgreen 1 amd64 green 2 ' , self . pending_requests )
self . assertIn ( ' lightgreen 1 i386 green 2 ' , self . pending_requests )
self . assertIn ( ' lightgreen 1 i386 green 2 ' , self . pending_requests )
def test_multi_rdepends_with_tests_regression ( self ) :
''' Multiple reverse dependencies with tests (regression) '''
self . swift . set_results ( { ' autopkgtest-series ' : {
' series/i386/d/darkgreen/20150101_100000@ ' : ( 0 , ' darkgreen 1 ' ) ,
' series/amd64/d/darkgreen/20150101_100000@ ' : ( 0 , ' darkgreen 1 ' ) ,
' series/i386/l/lightgreen/20150101_100100@ ' : ( 0 , ' lightgreen 1 ' ) ,
' series/i386/l/lightgreen/20150101_100101@ ' : ( 4 , ' lightgreen 1 ' ) ,
' series/amd64/l/lightgreen/20150101_100100@ ' : ( 0 , ' lightgreen 1 ' ) ,
' series/amd64/l/lightgreen/20150101_100101@ ' : ( 4 , ' lightgreen 1 ' ) ,
' series/i386/g/green/20150101_100200@ ' : ( 0 , ' green 2 ' ) ,
' series/amd64/g/green/20150101_100200@ ' : ( 0 , ' green 2 ' ) ,
' series/amd64/g/green/20150101_100201@ ' : ( 4 , ' green 2 ' ) ,
} } )
out = self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
NOT_CONSIDERED ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for green 2: .*amd64.*Regression.*i386.*Pass ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*Regression.*i386.*Regression ' ,
r ' autopkgtest for darkgreen 1: .*amd64.*Pass.*i386.*Pass ' ] )
self . assertEqual ( self . pending_requests , ' ' )
# not expecting any failures to retrieve from swift
self . assertNotIn ( ' Failure ' , out , out )
def test_multi_rdepends_with_tests_regression_last_pass ( self ) :
''' Multiple reverse dependencies with tests (regression), last one passes
This ensures that we don ' t just evaluate the test result of the last
test , but all of them .
'''
self . swift . set_results ( { ' autopkgtest-series ' : {
' series/i386/d/darkgreen/20150101_100000@ ' : ( 0 , ' darkgreen 1 ' ) ,
' series/amd64/d/darkgreen/20150101_100000@ ' : ( 0 , ' darkgreen 1 ' ) ,
' series/i386/l/lightgreen/20150101_100100@ ' : ( 0 , ' lightgreen 1 ' ) ,
' series/amd64/l/lightgreen/20150101_100100@ ' : ( 0 , ' lightgreen 1 ' ) ,
' series/i386/g/green/20150101_100200@ ' : ( 0 , ' green 2 ' ) ,
' series/amd64/g/green/20150101_100200@ ' : ( 0 , ' green 2 ' ) ,
' series/amd64/g/green/20150101_100201@ ' : ( 4 , ' green 2 ' ) ,
} } )
out = self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
NOT_CONSIDERED ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for green 2: .*amd64.*Regression.*i386.*Pass ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*Pass.*i386.*Pass ' ,
r ' autopkgtest for darkgreen 1: .*amd64.*Pass.*i386.*Pass ' ] )
self . assertEqual ( self . pending_requests , ' ' )
# not expecting any failures to retrieve from swift
self . assertNotIn ( ' Failure ' , out , out )
def test_multi_rdepends_with_tests_always_failed ( self ) :
''' Multiple reverse dependencies with tests (always failed) '''
self . swift . set_results ( { ' autopkgtest-series ' : {
' series/i386/d/darkgreen/20150101_100000@ ' : ( 0 , ' darkgreen 1 ' ) ,
' series/amd64/d/darkgreen/20150101_100000@ ' : ( 0 , ' darkgreen 1 ' ) ,
' series/i386/l/lightgreen/20150101_100100@ ' : ( 4 , ' lightgreen 1 ' ) ,
' series/i386/l/lightgreen/20150101_100101@ ' : ( 4 , ' lightgreen 1 ' ) ,
' series/amd64/l/lightgreen/20150101_100100@ ' : ( 4 , ' lightgreen 1 ' ) ,
' series/amd64/l/lightgreen/20150101_100101@ ' : ( 4 , ' lightgreen 1 ' ) ,
' series/i386/g/green/20150101_100200@ ' : ( 0 , ' green 2 ' ) ,
' series/amd64/g/green/20150101_100200@ ' : ( 4 , ' green 2 ' ) ,
' series/amd64/g/green/20150101_100201@ ' : ( 4 , ' green 2 ' ) ,
} } )
out = self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for green 2: .*amd64.*Always failed.*i386.*Pass ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*Always failed.*i386.*Always failed ' ,
r ' autopkgtest for darkgreen 1: .*amd64.*Pass.*i386.*Pass ' ] )
self . assertEqual ( self . pending_requests , ' ' )
# not expecting any failures to retrieve from swift
self . assertNotIn ( ' Failure ' , out , out )
def test_hint_force_badtest ( self ) :
''' force-badtest hint '''
self . swift . set_results ( { ' autopkgtest-series ' : {
' series/i386/d/darkgreen/20150101_100000@ ' : ( 0 , ' darkgreen 1 ' ) ,
' series/amd64/d/darkgreen/20150101_100000@ ' : ( 0 , ' darkgreen 1 ' ) ,
' series/i386/l/lightgreen/20150101_100100@ ' : ( 0 , ' lightgreen 1 ' ) ,
' series/i386/l/lightgreen/20150101_100101@ ' : ( 4 , ' lightgreen 1 ' ) ,
' series/amd64/l/lightgreen/20150101_100100@ ' : ( 0 , ' lightgreen 1 ' ) ,
' series/amd64/l/lightgreen/20150101_100101@ ' : ( 4 , ' lightgreen 1 ' ) ,
' series/i386/g/green/20150101_100200@ ' : ( 0 , ' green 2 ' ) ,
' series/amd64/g/green/20150101_100200@ ' : ( 0 , ' green 2 ' ) ,
} } )
self . create_hint ( ' pitti ' , ' force-badtest lightgreen/1 ' )
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for green 2: .*amd64.*Pass.*i386.*Pass ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*Regression.*i386.*Regression ' ,
r ' autopkgtest for darkgreen 1: .*amd64.*Pass.*i386.*Pass ' ,
r ' Should wait for lightgreen 1 test, but forced by pitti ' ] )
def test_hint_force_badtest_different_version ( self ) :
''' force-badtest hint with non-matching version '''
self . swift . set_results ( { ' autopkgtest-series ' : {
' series/i386/d/darkgreen/20150101_100000@ ' : ( 0 , ' darkgreen 1 ' ) ,
' series/amd64/d/darkgreen/20150101_100000@ ' : ( 0 , ' darkgreen 1 ' ) ,
' series/i386/l/lightgreen/20150101_100100@ ' : ( 0 , ' lightgreen 1 ' ) ,
' series/i386/l/lightgreen/20150101_100101@ ' : ( 4 , ' lightgreen 1 ' ) ,
' series/amd64/l/lightgreen/20150101_100100@ ' : ( 0 , ' lightgreen 1 ' ) ,
' series/amd64/l/lightgreen/20150101_100101@ ' : ( 4 , ' lightgreen 1 ' ) ,
' series/i386/g/green/20150101_100200@ ' : ( 0 , ' green 2 ' ) ,
' series/amd64/g/green/20150101_100200@ ' : ( 0 , ' green 2 ' ) ,
} } )
self . create_hint ( ' pitti ' , ' force-badtest lightgreen/0.1 ' )
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
NOT_CONSIDERED ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for green 2: .*amd64.*Pass.*i386.*Pass ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*Regression.*i386.*Regression ' ,
r ' autopkgtest for darkgreen 1: .*amd64.*Pass.*i386.*Pass ' ] ,
[ ' Should wait ' ] )
def test_hint_force_skiptest ( self ) :
''' force-skiptest hint '''
self . create_hint ( ' pitti ' , ' force-skiptest green/2 ' )
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for green 2: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for darkgreen 1: .*amd64.*in progress.*i386.*in progress ' ,
r ' Should wait for.*tests.*green 2.*forced by pitti ' ] )
def test_hint_force_skiptest_different_version ( self ) :
''' force-skiptest hint with non-matching version '''
self . create_hint ( ' pitti ' , ' force-skiptest green/1 ' )
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
NOT_CONSIDERED ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for green 2: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for darkgreen 1: .*amd64.*in progress.*i386.*in progress ' ] ,
[ ' Should wait ' ] )
def test_package_pair_running ( self ) :
def test_package_pair_running ( self ) :
''' Two packages in unstable that need to go in together (running) '''
''' Two packages in unstable that need to go in together (running) '''
self . do_test (
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ,
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ,
( ' lightgreen ' , { ' Version ' : ' 2 ' , ' Depends ' : ' libgreen1 (>= 2) ' } , ' autopkgtest ' ) ] ,
( ' lightgreen ' , { ' Version ' : ' 2 ' , ' Depends ' : ' libgreen1 (>= 2) ' } , ' autopkgtest ' ) ] ,
# FIXME: while we only submit requests through AMQP, but don't consider
NOT_CONSIDERED ,
# their results, we don't expect this to hold back stuff.
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
r ' \ blightgreen \ b.*>1</a> to .*>2< ' ] )
r ' \ blightgreen \ b.*>1</a> to .*>2< ' ] )
@ -300,6 +454,58 @@ lightgreen 2 i386 lightgreen 2
'''
'''
self . assertEqual ( self . pending_requests , expected_pending )
self . assertEqual ( self . pending_requests , expected_pending )
def test_binary_from_new_source_package_running ( self ) :
''' building an existing binary for a new source package (running) '''
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' newgreen ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
NOT_CONSIDERED ,
[ r ' \ bnewgreen \ b.* \ (- to .*>2< ' ,
r ' autopkgtest for newgreen 2: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for darkgreen 1: .*amd64.*in progress.*i386.*in progress ' ] )
self . assertEqual (
self . amqp_requests ,
set ( [ ' debci-series-i386:newgreen ' , ' debci-series-amd64:newgreen ' ,
' debci-series-i386:lightgreen ' , ' debci-series-amd64:lightgreen ' ,
' debci-series-i386:darkgreen ' , ' debci-series-amd64:darkgreen ' ] ) )
expected_pending = ''' darkgreen 1 amd64 newgreen 2
darkgreen 1 i386 newgreen 2
lightgreen 1 amd64 newgreen 2
lightgreen 1 i386 newgreen 2
newgreen 2 amd64 newgreen 2
newgreen 2 i386 newgreen 2
'''
self . assertEqual ( self . pending_requests , expected_pending )
def test_binary_from_new_source_package_pass ( self ) :
''' building an existing binary for a new source package (pass) '''
self . swift . set_results ( { ' autopkgtest-series ' : {
' series/i386/d/darkgreen/20150101_100000@ ' : ( 0 , ' darkgreen 1 ' ) ,
' series/amd64/d/darkgreen/20150101_100000@ ' : ( 0 , ' darkgreen 1 ' ) ,
' series/i386/l/lightgreen/20150101_100100@ ' : ( 0 , ' lightgreen 1 ' ) ,
' series/amd64/l/lightgreen/20150101_100100@ ' : ( 0 , ' lightgreen 1 ' ) ,
' series/i386/n/newgreen/20150101_100200@ ' : ( 0 , ' newgreen 2 ' ) ,
' series/amd64/n/newgreen/20150101_100201@ ' : ( 0 , ' newgreen 2 ' ) ,
} } )
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' newgreen ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
VALID_CANDIDATE ,
[ r ' \ bnewgreen \ b.* \ (- to .*>2< ' ,
r ' autopkgtest for newgreen 2: .*amd64.*Pass.*i386.*Pass ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*Pass.*i386.*Pass ' ,
r ' autopkgtest for darkgreen 1: .*amd64.*Pass.*i386.*Pass ' ] )
self . assertEqual (
self . amqp_requests ,
set ( [ ' debci-series-i386:newgreen ' , ' debci-series-amd64:newgreen ' ,
' debci-series-i386:lightgreen ' , ' debci-series-amd64:lightgreen ' ,
' debci-series-i386:darkgreen ' , ' debci-series-amd64:darkgreen ' ] ) )
self . assertEqual ( self . pending_requests , ' ' )
def test_result_from_older_version ( self ) :
def test_result_from_older_version ( self ) :
''' test result from older version than the uploaded one '''
''' test result from older version than the uploaded one '''
@ -310,9 +516,7 @@ lightgreen 2 i386 lightgreen 2
self . do_test (
self . do_test (
[ ( ' darkgreen ' , { ' Version ' : ' 2 ' , ' Depends ' : ' libc6 (>= 0.9), libgreen1 ' } , ' autopkgtest ' ) ] ,
[ ( ' darkgreen ' , { ' Version ' : ' 2 ' , ' Depends ' : ' libc6 (>= 0.9), libgreen1 ' } , ' autopkgtest ' ) ] ,
# FIXME: while we only submit requests through AMQP, but don't consider
NOT_CONSIDERED ,
# their results, we don't expect this to hold back stuff.
VALID_CANDIDATE ,
[ r ' \ bdarkgreen \ b.*>1</a> to .*>2< ' ,
[ r ' \ bdarkgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for darkgreen 2: .*amd64.*in progress.*i386.*in progress ' ] )
r ' autopkgtest for darkgreen 2: .*amd64.*in progress.*i386.*in progress ' ] )
@ -342,9 +546,7 @@ lightgreen 2 i386 lightgreen 2
self . data . remove_all ( True )
self . data . remove_all ( True )
self . do_test (
self . do_test (
[ ( ' darkgreen ' , { ' Version ' : ' 3 ' , ' Depends ' : ' libc6 (>= 0.9), libgreen1 ' } , ' autopkgtest ' ) ] ,
[ ( ' darkgreen ' , { ' Version ' : ' 3 ' , ' Depends ' : ' libc6 (>= 0.9), libgreen1 ' } , ' autopkgtest ' ) ] ,
# FIXME: while we only submit requests through AMQP, but don't consider
NOT_CONSIDERED ,
# their results, we don't expect this to hold back stuff.
VALID_CANDIDATE ,
[ r ' \ bdarkgreen \ b.*>1</a> to .*>3< ' ,
[ r ' \ bdarkgreen \ b.*>1</a> to .*>3< ' ,
r ' autopkgtest for darkgreen 3: .*amd64.*in progress.*i386.*in progress ' ] )
r ' autopkgtest for darkgreen 3: .*amd64.*in progress.*i386.*in progress ' ] )
self . assertEqual (
self . assertEqual (
@ -386,9 +588,7 @@ lightgreen 2 i386 lightgreen 2
# second run: new version re-triggers all tests
# second run: new version re-triggers all tests
self . do_test (
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 3 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
[ ( ' libgreen1 ' , { ' Version ' : ' 3 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
# FIXME: while we only submit requests through AMQP, but don't consider
NOT_CONSIDERED ,
# their results, we don't expect this to hold back stuff.
VALID_CANDIDATE ,
[ r ' \ green \ b.*>1</a> to .*>3< ' ,
[ r ' \ green \ b.*>1</a> to .*>3< ' ,
r ' autopkgtest for green 3: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for green 3: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*in progress.*i386.*in progress ' ,
@ -421,10 +621,7 @@ lightgreen 1 i386 green 3
' series/amd64/l/lightgreen/20150101_100010@ ' : ( 0 , ' lightgreen 1 ' ) ,
' series/amd64/l/lightgreen/20150101_100010@ ' : ( 0 , ' lightgreen 1 ' ) ,
} } )
} } )
self . do_test (
self . do_test (
[ ] ,
[ ] , NOT_CONSIDERED ,
# FIXME: while we only submit requests through AMQP, but don't consider
# their results, we don't expect this to hold back stuff.
VALID_CANDIDATE ,
[ r ' \ green \ b.*>1</a> to .*>3< ' ,
[ r ' \ green \ b.*>1</a> to .*>3< ' ,
r ' autopkgtest for green 3: .*amd64.*Pass.*i386.*Pass ' ,
r ' autopkgtest for green 3: .*amd64.*Pass.*i386.*Pass ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*Pass.*i386.*Pass ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*Pass.*i386.*Pass ' ,
@ -460,9 +657,7 @@ lightgreen 1 i386 green 3
self . do_test (
self . do_test (
[ ( ' lightgreen ' , { ' Version ' : ' 2 ' , ' Depends ' : ' libgreen1 (>= 1) ' } , ' autopkgtest ' ) ] ,
[ ( ' lightgreen ' , { ' Version ' : ' 2 ' , ' Depends ' : ' libgreen1 (>= 1) ' } , ' autopkgtest ' ) ] ,
# FIXME: while we only submit requests through AMQP, but don't consider
NOT_CONSIDERED ,
# their results, we don't expect this to hold back stuff.
VALID_CANDIDATE ,
[ r ' \ blightgreen \ b.*>1</a> to .*>2< ' ,
[ r ' \ blightgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for lightgreen 2: .*amd64.*Regression.*i386.*Regression ' ] ,
r ' autopkgtest for lightgreen 2: .*amd64.*Regression.*i386.*Regression ' ] ,
[ ' in progress ' ] )
[ ' in progress ' ] )
@ -488,9 +683,7 @@ lightgreen 1 i386 green 3
self . do_test (
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ] ,
# FIXME: while we only submit requests through AMQP, but don't consider
NOT_CONSIDERED ,
# their results, we don't expect this to hold back stuff.
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for green 2: .*amd64.*Regression.*i386.*Regression ' ,
r ' autopkgtest for green 2: .*amd64.*Regression.*i386.*Regression ' ,
r ' autopkgtest for lightgreen 1: .*amd64.*Regression.*i386.*Regression ' ] )
r ' autopkgtest for lightgreen 1: .*amd64.*Regression.*i386.*Regression ' ] )
@ -539,9 +732,7 @@ lightgreen 1 i386 green 3
self . do_test (
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ,
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } , ' autopkgtest ' ) ,
( ' lightgreen ' , { ' Version ' : ' 2 ' , ' Depends ' : ' libgreen1 (>= 2) ' } , ' autopkgtest ' ) ] ,
( ' lightgreen ' , { ' Version ' : ' 2 ' , ' Depends ' : ' libgreen1 (>= 2) ' } , ' autopkgtest ' ) ] ,
# FIXME: while we only submit requests through AMQP, but don't consider
NOT_CONSIDERED ,
# their results, we don't expect this to hold back stuff.
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
r ' \ blightgreen \ b.*>1</a> to .*>2< ' ,
r ' \ blightgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for green 2: .*amd64.*Pass.*i386.*Pass ' ,
r ' autopkgtest for green 2: .*amd64.*Pass.*i386.*Pass ' ,
@ -603,9 +794,7 @@ lightgreen 1 i386 green 3
self . do_test (
self . do_test (
[ ( ' lightgreen ' , { ' Version ' : ' 2 ' } , ' autopkgtest ' ) ] ,
[ ( ' lightgreen ' , { ' Version ' : ' 2 ' } , ' autopkgtest ' ) ] ,
# FIXME: while we only submit requests through AMQP, but don't consider
NOT_CONSIDERED ,
# their results, we don't expect this to hold back stuff.
VALID_CANDIDATE ,
[ r ' \ blightgreen \ b.*>1</a> to .*>2< ' ,
[ r ' \ blightgreen \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for lightgreen 2: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for lightgreen 2: .*amd64.*in progress.*i386.*in progress ' ,
r ' autopkgtest for rainbow 1: .*amd64.*in progress.*i386.*in progress ' ] )
r ' autopkgtest for rainbow 1: .*amd64.*in progress.*i386.*in progress ' ] )
@ -618,9 +807,7 @@ lightgreen 1 i386 green 3
self . do_test (
self . do_test (
[ ( ' dkms ' , { ' Version ' : ' 2 ' } , None ) ] ,
[ ( ' dkms ' , { ' Version ' : ' 2 ' } , None ) ] ,
# FIXME: while we only submit requests through AMQP, but don't consider
NOT_CONSIDERED ,
# their results, we don't expect this to hold back stuff.
VALID_CANDIDATE ,
[ r ' \ bdkms \ b.*>1</a> to .*>2< ' ,
[ r ' \ bdkms \ b.*>1</a> to .*>2< ' ,
r ' autopkgtest for fancy 1: .*amd64.*in progress.*i386.*in progress ' ] )
r ' autopkgtest for fancy 1: .*amd64.*in progress.*i386.*in progress ' ] )
@ -641,448 +828,5 @@ lightgreen 1 i386 green 3
self . assertEqual ( self . pending_requests , None )
self . assertEqual ( self . pending_requests , None )
class TestAdtBritney ( TestBase ) :
''' Legacy adt-britney/lp:auto-package-testing interface '''
def setUp ( self ) :
super ( TestAdtBritney , self ) . setUp ( )
# Mofify configuration according to the test context.
with open ( self . britney_conf , ' r ' ) as fp :
original_config = fp . read ( )
# Disable boottests.
new_config = original_config . replace (
' BOOTTEST_ENABLE = yes ' , ' BOOTTEST_ENABLE = no ' )
with open ( self . britney_conf , ' w ' ) as fp :
fp . write ( new_config )
# fake adt-britney script
self . adt_britney = os . path . join (
self . data . home , ' auto-package-testing ' , ' jenkins ' , ' adt-britney ' )
os . makedirs ( os . path . dirname ( self . adt_britney ) )
with open ( self . adt_britney , ' w ' ) as f :
f . write ( ''' #!/bin/sh -e
echo " $@ " >> / % s / adt - britney . log ''' % s elf.data.path)
os . chmod ( self . adt_britney , 0o755 )
# add a bunch of packages to testing to avoid repetition
self . data . add ( ' libc6 ' , False )
self . data . add ( ' libgreen1 ' , False , { ' Source ' : ' green ' ,
' Depends ' : ' libc6 (>= 0.9) ' } )
self . data . add ( ' green ' , False , { ' Depends ' : ' libc6 (>= 0.9), libgreen1 ' ,
' Conflicts ' : ' blue ' } )
self . data . add ( ' lightgreen ' , False , { ' Depends ' : ' libgreen1 ' } )
self . data . add ( ' darkgreen ' , False , { ' Depends ' : ' libgreen1 ' } )
self . data . add ( ' blue ' , False , { ' Depends ' : ' libc6 (>= 0.9) ' ,
' Conflicts ' : ' green ' } )
self . data . add ( ' justdata ' , False , { ' Architecture ' : ' all ' } )
def __merge_records ( self , results , history = " " ) :
''' Merges a list of results with records in history.
This function merges results from a collect with records already in
history and sort records by version / name of causes and version / name of
source packages with tests . This should be done in the fake
adt - britney but it is more convenient to just pass a static list of
records and make adt - britney just return this list .
'''
if history is None :
history = " "
records = [ x . split ( ) for x in ( results . strip ( ) + ' \n ' +
history . strip ( ) ) . split ( ' \n ' ) if x ]
records . sort ( cmp = apt_pkg . version_compare , key = operator . itemgetter ( 4 ) )
records . sort ( key = operator . itemgetter ( 3 ) )
records . sort ( cmp = apt_pkg . version_compare , key = operator . itemgetter ( 1 ) )
records . sort ( )
return " \n " . join ( [ ' ' . join ( x ) for x in records ] )
def make_adt_britney ( self , request , history = " " ) :
with open ( self . adt_britney , ' w ' ) as f :
f . write ( ''' #! %(py)s
import argparse , shutil , sys
def request ( ) :
if args . req :
shutil . copy ( args . req , ' %(path)s /adt-britney.requestarg ' )
with open ( args . output , ' w ' ) as f :
f . write ( """ %(rq)s """ . replace ( ' PASS ' , ' NEW ' ) . replace ( ' FAIL ' , ' NEW ' ) . replace ( ' RUNNING ' , ' NEW ' ) )
def submit ( ) :
with open ( args . req , ' w ' ) as f :
f . write ( """ %(rq)s """ . replace ( ' PASS ' , ' RUNNING ' ) .
replace ( ' FAIL ' , ' RUNNING ' ) )
def collect ( ) :
with open ( args . output , ' w ' ) as f :
f . write ( """ %(res)s """ )
p = argparse . ArgumentParser ( )
p . add_argument ( ' -c ' , ' --config ' )
p . add_argument ( ' -a ' , ' --arch ' )
p . add_argument ( ' -r ' , ' --release ' )
p . add_argument ( ' -P ' , ' --use-proposed ' , action = ' store_true ' )
p . add_argument ( ' -d ' , ' --debug ' , action = ' store_true ' )
p . add_argument ( ' -U ' , ' --no-update ' , action = ' store_true ' )
sp = p . add_subparsers ( )
prequest = sp . add_parser ( ' request ' )
prequest . add_argument ( ' -O ' , ' --output ' )
prequest . add_argument ( ' req ' , nargs = ' ? ' )
prequest . set_defaults ( func = request )
psubmit = sp . add_parser ( ' submit ' )
psubmit . add_argument ( ' req ' )
psubmit . set_defaults ( func = submit )
pcollect = sp . add_parser ( ' collect ' )
pcollect . add_argument ( ' -O ' , ' --output ' )
pcollect . add_argument ( ' -n ' , ' --new-only ' , action = ' store_true ' , default = False )
pcollect . set_defaults ( func = collect )
args = p . parse_args ( )
args . func ( )
''' % { ' py ' : sys.executable, ' path ' : self.data.path,
' rq ' : request ,
' res ' : self . __merge_records ( request , history ) } )
def do_test ( self , unstable_add , adt_request , considered , expect = None ,
no_expect = None , history = " " ) :
for ( pkg , fields ) in unstable_add :
self . data . add ( pkg , True , fields )
self . make_adt_britney ( adt_request , history )
( excuses , out ) = self . run_britney ( )
#print('-------\nexcuses: %s\n-----' % excuses)
#print('-------\nout: %s\n-----' % out)
#print('run:\n%s -c %s\n' % (self.britney, self.britney_conf))
#subprocess.call(['bash', '-i'], cwd=self.data.path)
if considered :
self . assertIn ( ' Valid candidate ' , excuses )
else :
self . assertIn ( ' Not considered ' , excuses )
if expect :
for re in expect :
self . assertRegexpMatches ( excuses , re )
if no_expect :
for re in no_expect :
self . assertNotRegexpMatches ( excuses , re )
def test_no_request_for_uninstallable ( self ) :
''' Does not request a test for an uninstallable package '''
self . do_test (
# uninstallable unstable version
[ ( ' green ' , { ' Version ' : ' 1.1~beta ' , ' Depends ' : ' libc6 (>= 0.9), libgreen1 (>= 2) ' } ) ] ,
' green 1.1~beta RUNNING green 1.1~beta \n ' ,
NOT_CONSIDERED ,
[ r ' \ bgreen \ b.*>1</a> to .*>1.1~beta< ' ,
' green/amd64 unsatisfiable Depends: libgreen1 \ (>= 2 \ ) ' ] ,
# autopkgtest should not be triggered for uninstallable pkg
[ ' autopkgtest ' ] )
def test_request_for_installable_running ( self ) :
''' Requests a test for an installable package, test still running '''
self . do_test (
[ ( ' green ' , { ' Version ' : ' 1.1~beta ' , ' Depends ' : ' libc6 (>= 0.9), libgreen1 ' } ) ] ,
' green 1.1~beta RUNNING green 1.1~beta \n ' ,
NOT_CONSIDERED ,
[ r ' \ bgreen \ b.*>1</a> to .*>1.1~beta< ' ,
' <li>autopkgtest for green 1.1~beta: %s ' % ADT_EXCUSES_LABELS [ ' RUNNING ' ] ] )
def test_request_for_installable_first_fail ( self ) :
''' Requests a test for an installable package. No history and first result is a failure '''
self . do_test (
[ ( ' green ' , { ' Version ' : ' 1.1~beta ' , ' Depends ' : ' libc6 (>= 0.9), libgreen1 ' } ) ] ,
' green 1.1~beta FAIL green 1.1~beta \n ' ,
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>1.1~beta< ' ,
' <li>autopkgtest for green 1.1~beta: %s ' % ADT_EXCUSES_LABELS [ ' ALWAYSFAIL ' ] ] )
def test_request_for_installable_fail_regression ( self ) :
''' Requests a test for an installable package, test fail '''
self . do_test (
[ ( ' green ' , { ' Version ' : ' 1.1~beta ' , ' Depends ' : ' libc6 (>= 0.9), libgreen1 ' } ) ] ,
' green 1.1~beta FAIL green 1.1~beta \n ' ,
NOT_CONSIDERED ,
[ r ' \ bgreen \ b.*>1</a> to .*>1.1~beta< ' ,
' <li>autopkgtest for green 1.1~beta: %s ' % ADT_EXCUSES_LABELS [ ' REGRESSION ' ] ] ,
history = ' green 1.0~beta PASS green 1.0~beta \n ' )
def test_request_for_installable_pass ( self ) :
''' Requests a test for an installable package, test pass '''
self . do_test (
[ ( ' green ' , { ' Version ' : ' 1.1~beta ' , ' Depends ' : ' libc6 (>= 0.9), libgreen1 ' } ) ] ,
' green 1.1~beta PASS green 1.1~beta \n ' ,
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>1.1~beta< ' ,
' <li>autopkgtest for green 1.1~beta: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ] )
def test_multi_rdepends_with_tests_running ( self ) :
''' Multiple reverse dependencies with tests (still running) '''
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } ) ] ,
' lightgreen 1 PASS green 2 \n '
' darkgreen 1 RUNNING green 2 \n ' ,
NOT_CONSIDERED ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ,
' <li>autopkgtest for darkgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' RUNNING ' ] ] )
def test_multi_rdepends_with_tests_fail_always ( self ) :
''' Multiple reverse dependencies with tests (fail) '''
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } ) ] ,
' lightgreen 1 PASS green 2 \n '
' darkgreen 1 FAIL green 2 \n ' ,
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ,
' <li>autopkgtest for darkgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' ALWAYSFAIL ' ] ] )
def test_multi_rdepends_with_tests_fail_regression ( self ) :
''' Multiple reverse dependencies with tests (fail) '''
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } ) ] ,
' lightgreen 1 PASS green 2 \n '
' darkgreen 1 FAIL green 2 \n ' ,
NOT_CONSIDERED ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ,
' <li>autopkgtest for darkgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' REGRESSION ' ] ] ,
history = ' darkgreen 1 PASS green 1 \n ' )
def test_multi_rdepends_with_tests_pass ( self ) :
''' Multiple reverse dependencies with tests (pass) '''
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } ) ] ,
' lightgreen 1 PASS green 2 \n '
' darkgreen 1 PASS green 2 \n ' ,
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ,
' <li>autopkgtest for darkgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ] )
def test_multi_rdepends_with_some_tests_running ( self ) :
''' Multiple reverse dependencies with some tests (running) '''
# add a third reverse dependency to libgreen1 which does not have a test
self . data . add ( ' mint ' , False , { ' Depends ' : ' libgreen1 ' } )
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } ) ] ,
' lightgreen 1 RUNNING green 2 \n '
' darkgreen 1 RUNNING green 2 \n ' ,
NOT_CONSIDERED ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' RUNNING ' ] ,
' <li>autopkgtest for darkgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' RUNNING ' ] ] )
def test_multi_rdepends_with_some_tests_fail_always ( self ) :
''' Multiple reverse dependencies with some tests (fail) '''
# add a third reverse dependency to libgreen1 which does not have a test
self . data . add ( ' mint ' , False , { ' Depends ' : ' libgreen1 ' } )
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } ) ] ,
' lightgreen 1 PASS green 2 \n '
' darkgreen 1 FAIL green 2 \n ' ,
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ,
' <li>autopkgtest for darkgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' ALWAYSFAIL ' ] ] )
def test_multi_rdepends_with_some_tests_fail_regression ( self ) :
''' Multiple reverse dependencies with some tests (fail) '''
# add a third reverse dependency to libgreen1 which does not have a test
self . data . add ( ' mint ' , False , { ' Depends ' : ' libgreen1 ' } )
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } ) ] ,
' lightgreen 1 PASS green 2 \n '
' darkgreen 1 FAIL green 2 \n ' ,
NOT_CONSIDERED ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ,
' <li>autopkgtest for darkgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' REGRESSION ' ] ] ,
history = ' darkgreen 1 PASS green 1 \n ' )
def test_multi_rdepends_with_some_tests_pass ( self ) :
''' Multiple reverse dependencies with some tests (pass) '''
# add a third reverse dependency to libgreen1 which does not have a test
self . data . add ( ' mint ' , False , { ' Depends ' : ' libgreen1 ' } )
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' green ' , ' Depends ' : ' libc6 ' } ) ] ,
' lightgreen 1 PASS green 2 \n '
' darkgreen 1 PASS green 2 \n ' ,
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>2< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ,
' <li>autopkgtest for darkgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ] )
def test_binary_from_new_source_package_running ( self ) :
''' building an existing binary for a new source package (running) '''
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' newgreen ' , ' Depends ' : ' libc6 ' } ) ] ,
' lightgreen 1 PASS newgreen 2 \n '
' darkgreen 1 RUNNING newgreen 2 \n ' ,
NOT_CONSIDERED ,
[ r ' \ bnewgreen \ b.* \ (- to .*>2< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ,
' <li>autopkgtest for darkgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' RUNNING ' ] ] )
def test_binary_from_new_source_package_fail_always ( self ) :
''' building an existing binary for a new source package (fail) '''
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' newgreen ' , ' Depends ' : ' libc6 ' } ) ] ,
' lightgreen 1 PASS newgreen 2 \n '
' darkgreen 1 FAIL newgreen 2 \n ' ,
VALID_CANDIDATE ,
[ r ' \ bnewgreen \ b.* \ (- to .*>2< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ,
' <li>autopkgtest for darkgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' ALWAYSFAIL ' ] ] )
def test_binary_from_new_source_package_fail_regression ( self ) :
''' building an existing binary for a new source package (fail) '''
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' newgreen ' , ' Depends ' : ' libc6 ' } ) ] ,
' lightgreen 1 PASS newgreen 2 \n '
' darkgreen 1 FAIL newgreen 2 \n ' ,
NOT_CONSIDERED ,
[ r ' \ bnewgreen \ b.* \ (- to .*>2< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ,
' <li>autopkgtest for darkgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' REGRESSION ' ] ] ,
history = ' darkgreen 1 PASS green 1 \n ' )
def test_binary_from_new_source_package_pass ( self ) :
''' building an existing binary for a new source package (pass) '''
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' newgreen ' , ' Depends ' : ' libc6 ' } ) ] ,
' lightgreen 1 PASS newgreen 2 \n '
' darkgreen 1 PASS newgreen 2 \n ' ,
VALID_CANDIDATE ,
[ r ' \ bnewgreen \ b.* \ (- to .*>2< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ,
' <li>autopkgtest for darkgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ] )
def test_binary_from_new_source_package_uninst ( self ) :
''' building an existing binary for a new source package (uninstallable) '''
self . do_test (
[ ( ' libgreen1 ' , { ' Version ' : ' 2 ' , ' Source ' : ' newgreen ' , ' Depends ' : ' libc6, nosuchpkg ' } ) ] ,
' darkgreen 1 FAIL newgreen 2 \n ' ,
NOT_CONSIDERED ,
[ r ' \ bnewgreen \ b.* \ (- to .*>2< ' ,
' libgreen1/amd64 unsatisfiable Depends: nosuchpkg ' ] ,
# autopkgtest should not be triggered for uninstallable pkg
[ ' autopkgtest ' ] )
@unittest . expectedFailure
def test_result_from_older_version ( self ) :
''' test result from older version than the uploaded one '''
self . do_test (
[ ( ' green ' , { ' Version ' : ' 1.1~beta ' , ' Depends ' : ' libc6 (>= 0.9), libgreen1 ' } ) ] ,
' green 1.1~alpha PASS green 1.1~beta \n ' ,
NOT_CONSIDERED ,
[ r ' \ bgreen \ b.*>1</a> to .*>1.1~beta< ' ,
# it's not entirely clear what precisely it should say here
' <li>autopkgtest for green 1.1~beta: %s ' % ADT_EXCUSES_LABELS [ ' RUNNING ' ] ] )
def test_request_for_installable_fail_regression_promoted ( self ) :
''' Requests a test for an installable package, test fail, is a regression.
This test verifies a bug in britney where a package was promoted if latest test
appeared before previous result in history , only the last result in
alphabetic order was taken into account . For example :
A 1 FAIL B 1
A 1 PASS A 1
In this case results for A 1 didn ' t appear in the list of results
triggered by the upload of B 1 and B 1 was promoted
'''
self . do_test (
[ ( ' green ' , { ' Version ' : ' 1.1~beta ' , ' Depends ' : ' libc6 (>= 0.9), libgreen1 ' } ) ] ,
' lightgreen 1 FAIL green 1.1~beta \n ' ,
NOT_CONSIDERED ,
[ r ' \ bgreen \ b.*>1</a> to .*>1.1~beta< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' REGRESSION ' ] ] ,
history = " lightgreen 1 PASS lightgreen 1 "
)
def test_history_always_passed ( self ) :
''' All the results in history are PASS, and test passed
'''
self . do_test (
[ ( ' green ' , { ' Version ' : ' 1.1~beta ' , ' Depends ' : ' libc6 (>= 0.9), libgreen1 ' } ) ] ,
' lightgreen 1 PASS green 1.1~beta \n ' ,
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>1.1~beta< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' PASS ' ] ] ,
history = " lightgreen 1 PASS lightgreen 1 "
)
def test_history_always_failed ( self ) :
''' All the results in history are FAIL, test fails. not a regression.
'''
self . do_test (
[ ( ' green ' , { ' Version ' : ' 1.1~beta ' , ' Depends ' : ' libc6 (>= 0.9), libgreen1 ' } ) ] ,
' lightgreen 1 FAIL green 1.1~beta \n ' ,
VALID_CANDIDATE ,
[ r ' \ bgreen \ b.*>1</a> to .*>1.1~beta< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' ALWAYSFAIL ' ] ] ,
history = " lightgreen 1 FAIL lightgreen 1 "
)
def test_history_regression ( self ) :
''' All the results in history are PASS, test fails. Blocked.
'''
self . do_test (
[ ( ' green ' , { ' Version ' : ' 1.1~beta ' , ' Depends ' : ' libc6 (>= 0.9), libgreen1 ' } ) ] ,
' lightgreen 1 FAIL green 1.1~beta \n ' ,
NOT_CONSIDERED ,
[ r ' \ bgreen \ b.*>1</a> to .*>1.1~beta< ' ,
' <li>autopkgtest for lightgreen 1: %s ' % ADT_EXCUSES_LABELS [ ' REGRESSION ' ] ] ,
history = " lightgreen 1 PASS lightgreen 1 "
)
def shell ( self ) :
# uninstallable unstable version
self . data . add ( ' yellow ' , True , { ' Version ' : ' 1.1~beta ' ,
' Depends ' : ' libc6 (>= 0.9), nosuchpkg ' } )
self . make_adt_britney ( ' yellow 1.1~beta RUNNING yellow 1.1~beta \n ' ,
' purple 2 FAIL pink 3.0.~britney \n ' )
print ( ' run: \n %s -c %s \n ' % ( self . britney , self . britney_conf ) )
subprocess . call ( [ ' bash ' , ' -i ' ] , cwd = self . data . path )
if __name__ == ' __main__ ' :
if __name__ == ' __main__ ' :
unittest . main ( )
unittest . main ( )