Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 # Copyright (c) 2011 Google Inc. All rights reserved. | 1 # Copyright (c) 2011 Google Inc. All rights reserved. |
| 2 # | 2 # |
| 3 # Redistribution and use in source and binary forms, with or without | 3 # Redistribution and use in source and binary forms, with or without |
| 4 # modification, are permitted provided that the following conditions are | 4 # modification, are permitted provided that the following conditions are |
| 5 # met: | 5 # met: |
| 6 # | 6 # |
| 7 # * Redistributions of source code must retain the above copyright | 7 # * Redistributions of source code must retain the above copyright |
| 8 # notice, this list of conditions and the following disclaimer. | 8 # notice, this list of conditions and the following disclaimer. |
| 9 # * Redistributions in binary form must reproduce the above | 9 # * Redistributions in binary form must reproduce the above |
| 10 # copyright notice, this list of conditions and the following disclaimer | 10 # copyright notice, this list of conditions and the following disclaimer |
| (...skipping 14 matching lines...) Expand all Loading... | |
| 25 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 25 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| 26 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 26 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| 27 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 27 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 28 | 28 |
| 29 import logging | 29 import logging |
| 30 import os | 30 import os |
| 31 import optparse | 31 import optparse |
| 32 from webkitpy.tool.multicommandtool import AbstractDeclarativeCommand | 32 from webkitpy.tool.multicommandtool import AbstractDeclarativeCommand |
| 33 from webkitpy.layout_tests.layout_package.bot_test_expectations import BotTestEx pectationsFactory | 33 from webkitpy.layout_tests.layout_package.bot_test_expectations import BotTestEx pectationsFactory |
| 34 from webkitpy.layout_tests.models.test_expectations import TestExpectationParser , TestExpectationsModel, TestExpectations | 34 from webkitpy.layout_tests.models.test_expectations import TestExpectationParser , TestExpectationsModel, TestExpectations |
| 35 from webkitpy.layout_tests.port import builders | 35 from webkitpy.layout_tests.port.builders import Builders |
|
qyearsley
2016/05/02 21:56:36
This import may be unnecessary now. I don't see wh
bokan
2016/05/04 11:58:47
Done.
| |
| 36 from webkitpy.common.net import sheriff_calendar | 36 from webkitpy.common.net import sheriff_calendar |
| 37 | 37 |
| 38 | 38 |
| 39 _log = logging.getLogger(__name__) | 39 _log = logging.getLogger(__name__) |
| 40 | 40 |
| 41 | 41 |
| 42 class FlakyTests(AbstractDeclarativeCommand): | 42 class FlakyTests(AbstractDeclarativeCommand): |
| 43 name = "print-flaky-tests" | 43 name = "print-flaky-tests" |
| 44 help_text = "Print out flaky lines from the flakiness dashboard" | 44 help_text = "Print out flaky lines from the flakiness dashboard" |
| 45 show_in_main_help = True | 45 show_in_main_help = True |
| (...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 100 | 100 |
| 101 final_model = None | 101 final_model = None |
| 102 for model in models: | 102 for model in models: |
| 103 if final_model: | 103 if final_model: |
| 104 final_model.merge_model(model) | 104 final_model.merge_model(model) |
| 105 else: | 105 else: |
| 106 final_model = model | 106 final_model = model |
| 107 return final_model._test_to_expectation_line.values() | 107 return final_model._test_to_expectation_line.values() |
| 108 | 108 |
| 109 def execute(self, options, args, tool): | 109 def execute(self, options, args, tool): |
| 110 factory = self.expectations_factory() | 110 factory = self.expectations_factory(tool.builders) |
| 111 lines = self._collect_expectation_lines(builders.all_builder_names(), fa ctory) | 111 lines = self._collect_expectation_lines(tool.builders.all_builder_names( ), factory) |
| 112 lines.sort(key=lambda line: line.path) | 112 lines.sort(key=lambda line: line.path) |
| 113 | 113 |
| 114 port = tool.port_factory.get() | 114 port = tool.port_factory.get() |
| 115 # Skip any tests which are mentioned in the dashboard but not in our che ckout: | 115 # Skip any tests which are mentioned in the dashboard but not in our che ckout: |
| 116 fs = tool.filesystem | 116 fs = tool.filesystem |
| 117 lines = filter(lambda line: fs.exists(fs.join(port.layout_tests_dir(), l ine.path)), lines) | 117 lines = filter(lambda line: fs.exists(fs.join(port.layout_tests_dir(), l ine.path)), lines) |
| 118 | 118 |
| 119 test_names = [line.name for line in lines] | 119 test_names = [line.name for line in lines] |
| 120 flakiness_dashbord_url = self.FLAKINESS_DASHBOARD_URL % ','.join(test_na mes) | 120 flakiness_dashbord_url = self.FLAKINESS_DASHBOARD_URL % ','.join(test_na mes) |
| 121 expectations_string = TestExpectations.list_to_string(lines) | 121 expectations_string = TestExpectations.list_to_string(lines) |
| 122 | 122 |
| 123 # pylint: disable=E1601 | 123 # pylint: disable=E1601 |
| 124 print self.OUTPUT % (self.HEADER, expectations_string, flakiness_dashbor d_url) | 124 print self.OUTPUT % (self.HEADER, expectations_string, flakiness_dashbor d_url) |
| OLD | NEW |