%PDF- <> %âãÏÓ endobj 2 0 obj <> endobj 3 0 obj <>/ExtGState<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI] >>/Annots[ 28 0 R 29 0 R] /MediaBox[ 0 0 595.5 842.25] /Contents 4 0 R/Group<>/Tabs/S>> endobj ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<> endobj 2 0 obj<>endobj 2 0 obj<>es 3 0 R>> endobj 2 0 obj<> ox[ 0.000000 0.000000 609.600000 935.600000]/Fi endobj 3 0 obj<> endobj 7 1 obj<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI]>>/Subtype/Form>> stream
# Copyright 2017 the V8 project authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. from ..local import statusfile from ..outproc import base as outproc_base from ..testproc import base as testproc_base from ..testproc.result import Result # Only check the exit code of the predictable_wrapper in # verify-predictable mode. Negative tests are not supported as they # usually also don't print allocation hashes. There are two versions of # negative tests: one specified by the test, the other specified through # the status file (e.g. known bugs). def get_outproc(test): return OutProc(test.output_proc) class OutProc(outproc_base.BaseOutProc): """Output processor wrapper for predictable mode. It has custom process and has_unexpected_output implementation, but for all other methods it simply calls wrapped output processor. """ def __init__(self, _outproc): super(OutProc, self).__init__() self._outproc = _outproc def has_unexpected_output(self, output): return output.exit_code != 0 def get_outcome(self, output): return self._outproc.get_outcome(output) @property def negative(self): return self._outproc.negative @property def expected_outcomes(self): return self._outproc.expected_outcomes class PredictableFilterProc(testproc_base.TestProcFilter): def _filter(self, test): return test.skip_predictable()