Title: [260871] branches/safari-609-branch/Tools
Revision
260871
Author
[email protected]
Date
2020-04-28 22:43:13 -0700 (Tue, 28 Apr 2020)

Log Message

Unreviewed, cherry-pick scripts from r259811. rdar://62268126

* BuildSlaveSupport/trigger-crash-log-submission: Added.
* BuildSlaveSupport/wait-for-crash-collection: Added.

Modified Paths

Added Paths

Diff

Added: branches/safari-609-branch/Tools/BuildSlaveSupport/trigger-crash-log-submission (0 => 260871)


--- branches/safari-609-branch/Tools/BuildSlaveSupport/trigger-crash-log-submission	                        (rev 0)
+++ branches/safari-609-branch/Tools/BuildSlaveSupport/trigger-crash-log-submission	2020-04-29 05:43:13 UTC (rev 260871)
@@ -0,0 +1,53 @@
+#!/usr/bin/env python
+# Copyright (C) 2020 Apple 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:
+#
+# 1.  Redistributions of source code must retain the above copyright
+#     notice, this list of conditions and the following disclaimer.
+# 2.  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.
+#
+# THIS SOFTWARE IS PROVIDED BY APPLE AND ITS 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 APPLE OR ITS 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 subprocess
+import sys
+import time
+
+WAIT_SECONDS = 3
+
+
+def main():
+    if sys.platform != 'darwin':
+        print("No crash log submission available for platform '{}'".format(sys.platform))
+        return 0
+
+    # Workaround for <rdar://problem/60507877>.
+    if subprocess.call(['/usr/bin/killall', '-9', 'diagnostics_agent']):
+        print('Failed to kill diagnostics_agent')
+        return 1
+    print('Killed diagnostics_agent')
+
+    time.sleep(WAIT_SECONDS)
+    if subprocess.call(['/usr/bin/notifyutil', '-p', 'com.apple.crashreporter.debug.submit.now']):
+        print('Failed to trigger crash log submission')
+        return 1
+    print('Triggered crash log submission')
+
+    return 0
+
+
+if __name__ == '__main__':
+    sys.exit(main())
Property changes on: branches/safari-609-branch/Tools/BuildSlaveSupport/trigger-crash-log-submission
___________________________________________________________________

Added: svn:executable

+* \ No newline at end of property

Added: branches/safari-609-branch/Tools/BuildSlaveSupport/wait-for-crash-collection (0 => 260871)


--- branches/safari-609-branch/Tools/BuildSlaveSupport/wait-for-crash-collection	                        (rev 0)
+++ branches/safari-609-branch/Tools/BuildSlaveSupport/wait-for-crash-collection	2020-04-29 05:43:13 UTC (rev 260871)
@@ -0,0 +1,89 @@
+#!/usr/bin/env python
+# Copyright (C) 2020 Apple 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:
+#
+# 1.  Redistributions of source code must retain the above copyright
+#     notice, this list of conditions and the following disclaimer.
+# 2.  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.
+#
+# THIS SOFTWARE IS PROVIDED BY APPLE AND ITS 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 APPLE OR ITS 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 argparse
+import subprocess
+import sys
+import time
+
+
+SUBMIT_DIAG_INFO = '/System/Library/CoreServices/SubmitDiagInfo'
+WAIT_SECONDS = 3
+
+
+def pid_for_name(process_name):
+    process = subprocess.Popen(['/bin/ps', '-eo', 'pid,comm'], stdout=subprocess.PIPE, stderr=subprocess.PIPE)
+
+    stdout, _ = process.communicate()
+    for line in stdout.splitlines():
+        try:
+            pid, candidate = line.strip().split(b' ', 1)
+            if candidate == process_name:
+                return int(pid)
+        except ValueError:
+            pass
+    return None
+
+
+def cpu_percentage(pid):
+    top_output = subprocess.check_output(['/usr/bin/top', '-pid', str(pid), '-stats', 'cpu', '-l', '2'])
+    try:
+        return float(top_output.splitlines()[-1])
+    except ValueError:
+        return 0
+
+
+def main():
+    parser = argparse.ArgumentParser(description='Wait for crash log reporting to quiesce')
+    parser.add_argument(
+        '-t', '--timeout',
+        help='Seconds to wait for process to quiesce.',
+        type=int, default=0,
+    )
+    args = parser.parse_args()
+    deadline = (time.time() + args.timeout) if args.timeout else None
+
+    if sys.platform != 'darwin':
+        print("No crash reporting available for platform '{}'".format(sys.platform))
+        return 0
+
+    pid = pid_for_name(SUBMIT_DIAG_INFO)
+    if not pid:
+        print('Failed to find any running process for {}'.format(SUBMIT_DIAG_INFO))
+        return 0
+    print('Found {} running with PID {}'.format(SUBMIT_DIAG_INFO, pid))
+
+    print('Waiting for process {} to quiesce'.format(pid))
+    while not deadline or deadline > time.time():
+        if cpu_percentage(pid) <= 5:
+            print('Process {} has quiesced'.format(pid))
+            return 0
+        time.sleep(WAIT_SECONDS)
+
+    print('Timed out waiting for {} to quiesce, continue'.format(pid))
+    return 0
+
+
+if __name__ == '__main__':
+    sys.exit(main())
Property changes on: branches/safari-609-branch/Tools/BuildSlaveSupport/wait-for-crash-collection
___________________________________________________________________

Added: svn:executable

+* \ No newline at end of property

Modified: branches/safari-609-branch/Tools/ChangeLog (260870 => 260871)


--- branches/safari-609-branch/Tools/ChangeLog	2020-04-29 05:36:17 UTC (rev 260870)
+++ branches/safari-609-branch/Tools/ChangeLog	2020-04-29 05:43:13 UTC (rev 260871)
@@ -1,3 +1,10 @@
+2020-04-28  Ryan Haddad  <[email protected]>
+
+        Unreviewed, cherry-pick scripts from r259811. rdar://62268126
+
+        * BuildSlaveSupport/trigger-crash-log-submission: Added.
+        * BuildSlaveSupport/wait-for-crash-collection: Added.
+
 2020-04-20  Alan Coon  <[email protected]>
 
         Apply patch. rdar://problem/61950472
_______________________________________________
webkit-changes mailing list
[email protected]
https://lists.webkit.org/mailman/listinfo/webkit-changes

Reply via email to