diff options
Diffstat (limited to 'Tools/Scripts/webkitpy/tool/commands/analyzechangelog_unittest.py')
-rw-r--r-- | Tools/Scripts/webkitpy/tool/commands/analyzechangelog_unittest.py | 185 |
1 files changed, 185 insertions, 0 deletions
diff --git a/Tools/Scripts/webkitpy/tool/commands/analyzechangelog_unittest.py b/Tools/Scripts/webkitpy/tool/commands/analyzechangelog_unittest.py new file mode 100644 index 000000000..661d2d85f --- /dev/null +++ b/Tools/Scripts/webkitpy/tool/commands/analyzechangelog_unittest.py @@ -0,0 +1,185 @@ +# Cpyright (c) 2011 Google Inc. All rights reserved. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted provided that the following conditions are +# met: +# +# * Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# * Redistributions in binary form must reproduce the above +# copyright notice, this list of conditions and the following disclaimer +# in the documentation and/or other materials provided with the +# distribution. +# * Neither the name of Google Inc. nor the names of its +# contributors may be used to endorse or promote products derived from +# this software without specific prior written permission. +# +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS +# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT +# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR +# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT +# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, +# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT +# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT +# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE +# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + +import json +import sys +from webkitpy.common.config.contributionareas import ContributionAreas +from webkitpy.common.host_mock import MockHost +from webkitpy.common.system.filesystem_mock import MockFileSystem +from webkitpy.common.system.executive import Executive +from webkitpy.common.system.outputcapture import OutputCapture +from webkitpy.tool.commands.analyzechangelog import AnalyzeChangeLog +from webkitpy.tool.commands.analyzechangelog import ChangeLogAnalyzer +from webkitpy.tool.commands.commandtest import CommandsTest +from webkitpy.tool.multicommandtool import AbstractDeclarativeCommand + + +class AnalyzeChangeLogTest(CommandsTest): + def test_enumerate_enumerate_changelogs(self): + filesystem = MockFileSystem({ + 'foo/ChangeLog': '', + 'foo/ChangeLog-2010-06-23': '', + 'foo/ChangeLog-2010-12-31': '', + 'foo/ChangeLog-x': '', + 'foo/ChangeLog-2011-01-01': '', + }) + changelogs = AnalyzeChangeLog._enumerate_changelogs(filesystem, 'foo/', None) + self.assertEqual(changelogs, ['foo/ChangeLog', 'foo/ChangeLog-2011-01-01', 'foo/ChangeLog-2010-12-31', 'foo/ChangeLog-2010-06-23']) + + changelogs = AnalyzeChangeLog._enumerate_changelogs(filesystem, 'foo/', 2) + self.assertEqual(changelogs, ['foo/ChangeLog', 'foo/ChangeLog-2011-01-01']) + + def test_generate_jsons(self): + filesystem = MockFileSystem() + test_json = {'array.json': [1, 2, 3, {'key': 'value'}], 'dictionary.json': {'somekey': 'somevalue', 'array': [4, 5]}} + + capture = OutputCapture() + capture.capture_output() + + AnalyzeChangeLog._generate_jsons(filesystem, test_json, 'bar') + self.assertEqual(set(filesystem.files.keys()), set(['bar/array.json', 'bar/dictionary.json'])) + + capture.restore_output() + + self.assertEqual(json.loads(filesystem.files['bar/array.json']), test_json['array.json']) + self.assertEqual(json.loads(filesystem.files['bar/dictionary.json']), test_json['dictionary.json']) + + +class ChangeLogAnalyzerTest(CommandsTest): + def test_analyze_one_changelog(self): + host = MockHost() + host.filesystem.files['mock-checkout/foo/ChangeLog'] = u"""2011-11-17 Mark Rowe <mrowe@apple.com> + + <http://webkit.org/b/72646> Disable deprecation warnings around code where we cannot easily + switch away from the deprecated APIs. + + Reviewed by Sam Weinig. + + * platform/mac/WebCoreNSStringExtras.mm: + * platform/network/cf/SocketStreamHandleCFNet.cpp: + (WebCore::SocketStreamHandle::reportErrorToClient): + +2011-11-19 Kevin Ollivier <kevino@theolliviers.com> + + [wx] C++ bindings build fix for move of array classes to WTF. + + * bindings/scripts/CodeGeneratorCPP.pm: + (GetCPPTypeGetter): + (GetNamespaceForClass): + (GenerateHeader): + (GenerateImplementation): + +2011-10-27 Philippe Normand <pnormand@igalia.com> and Zan Dobersek <zandobersek@gmail.com> + + [GStreamer] WebAudio AudioFileReader implementation + https://bugs.webkit.org/show_bug.cgi?id=69834 + + Reviewed by Martin Robinson. + + Basic FileReader implementation, supporting one or 2 audio + channels. An empty AudioDestination is also provided, its complete + implementation is handled in bug 69835. + + * GNUmakefile.am: + * GNUmakefile.list.am: + * platform/audio/gstreamer/AudioDestinationGStreamer.cpp: Added. + (WebCore::AudioDestination::create): + (WebCore::AudioDestination::hardwareSampleRate): + (WebCore::AudioDestinationGStreamer::AudioDestinationGStreamer): + (WebCore::AudioDestinationGStreamer::~AudioDestinationGStreamer): + (WebCore::AudioDestinationGStreamer::start): + (WebCore::AudioDestinationGStreamer::stop): + * platform/audio/gstreamer/AudioDestinationGStreamer.h: Added. + (WebCore::AudioDestinationGStreamer::isPlaying): + (WebCore::AudioDestinationGStreamer::sampleRate): + (WebCore::AudioDestinationGStreamer::sourceProvider): + * platform/audio/gstreamer/AudioFileReaderGStreamer.cpp: Added. + (WebCore::getGStreamerAudioCaps): + (WebCore::getFloatFromByteReader): + (WebCore::copyGstreamerBuffersToAudioChannel): + (WebCore::onAppsinkNewBufferCallback): + (WebCore::messageCallback): + (WebCore::onGStreamerDeinterleavePadAddedCallback): + (WebCore::onGStreamerDeinterleaveReadyCallback): + (WebCore::onGStreamerDecodebinPadAddedCallback): + (WebCore::AudioFileReader::AudioFileReader): + (WebCore::AudioFileReader::~AudioFileReader): + (WebCore::AudioFileReader::handleBuffer): + (WebCore::AudioFileReader::handleMessage): + (WebCore::AudioFileReader::handleNewDeinterleavePad): + (WebCore::AudioFileReader::deinterleavePadsConfigured): + (WebCore::AudioFileReader::plugDeinterleave): + (WebCore::AudioFileReader::createBus): + (WebCore::createBusFromAudioFile): + (WebCore::createBusFromInMemoryAudioFile): + * platform/audio/gtk/AudioBusGtk.cpp: Added. + (WebCore::AudioBus::loadPlatformResource): +""" + + capture = OutputCapture() + capture.capture_output() + + analyzer = ChangeLogAnalyzer(host, ['mock-checkout/foo/ChangeLog']) + analyzer.analyze() + + capture.restore_output() + + self.assertEqual(analyzer.summary(), + {'reviewed': 2, 'unreviewed': 1, 'contributors': 6, 'contributors_with_reviews': 2, 'contributors_without_reviews': 4}) + + self.assertEqual(set(analyzer.contributors_statistics().keys()), + set(['Sam Weinig', u'Mark Rowe', u'Kevin Ollivier', 'Martin Robinson', u'Philippe Normand', u'Zan Dobersek'])) + + self.assertEqual(analyzer.contributors_statistics()['Sam Weinig'], + {'reviews': {'files': {u'foo/platform/mac/WebCoreNSStringExtras.mm': 1, u'foo/platform/network/cf/SocketStreamHandleCFNet.cpp': 1}, + 'total': 1, 'areas': {'Network': 1}}, 'patches': {'files': {}, 'areas': {}, 'unreviewed': 0, 'reviewed': 0}}) + self.assertEqual(analyzer.contributors_statistics()[u'Mark Rowe'], + {'reviews': {'files': {}, 'total': 0, 'areas': {}}, 'patches': {'files': {u'foo/platform/mac/WebCoreNSStringExtras.mm': 1, + u'foo/platform/network/cf/SocketStreamHandleCFNet.cpp': 1}, 'areas': {'Network': 1}, 'unreviewed': 0, 'reviewed': 1}}) + self.assertEqual(analyzer.contributors_statistics()[u'Kevin Ollivier'], + {'reviews': {'files': {}, 'total': 0, 'areas': {}}, 'patches': {'files': {u'foo/bindings/scripts/CodeGeneratorCPP.pm': 1}, + 'areas': {'Bindings': 1}, 'unreviewed': 1, 'reviewed': 0}}) + + files_for_audio_patch = {u'foo/GNUmakefile.am': 1, u'foo/GNUmakefile.list.am': 1, 'foo/platform/audio/gstreamer/AudioDestinationGStreamer.cpp': 1, + 'foo/platform/audio/gstreamer/AudioDestinationGStreamer.h': 1, 'foo/platform/audio/gstreamer/AudioFileReaderGStreamer.cpp': 1, + 'foo/platform/audio/gtk/AudioBusGtk.cpp': 1} + author_expectation_for_audio_patch = {'reviews': {'files': {}, 'total': 0, 'areas': {}}, + 'patches': {'files': files_for_audio_patch, 'areas': {'The WebKitGTK+ Port': 1}, 'unreviewed': 0, 'reviewed': 1}} + self.assertEqual(analyzer.contributors_statistics()[u'Martin Robinson'], + {'reviews': {'files': files_for_audio_patch, 'total': 1, 'areas': {'The WebKitGTK+ Port': 1}}, + 'patches': {'files': {}, 'areas': {}, 'unreviewed': 0, 'reviewed': 0}}) + self.assertEqual(analyzer.contributors_statistics()[u'Philippe Normand'], author_expectation_for_audio_patch) + self.assertEqual(analyzer.contributors_statistics()[u'Zan Dobersek'], author_expectation_for_audio_patch) + + areas_statistics = analyzer.areas_statistics() + areas_with_patches = [area for area in areas_statistics if areas_statistics[area]['reviewed'] or areas_statistics[area]['unreviewed']] + self.assertEqual(set(areas_with_patches), set(['Bindings', 'Network', 'The WebKitGTK+ Port'])) + self.assertEqual(areas_statistics['Bindings'], {'unreviewed': 1, 'reviewed': 0, 'contributors': + {u'Kevin Ollivier': {'reviews': 0, 'unreviewed': 1, 'reviewed': 0}}}) + self.assertEqual(areas_statistics['Network'], {'unreviewed': 0, 'reviewed': 1, 'contributors': + {'Sam Weinig': {'reviews': 1, 'unreviewed': 0, 'reviewed': 0}, u'Mark Rowe': {'reviews': 0, 'unreviewed': 0, 'reviewed': 1}}}) |