From ca005cb8245e7e12ad808d78d49bce3953e1153c Mon Sep 17 00:00:00 2001
From: Misty De Meo <mistydemeo@github.com>
Date: Tue, 5 Jul 2016 11:02:16 +1000
Subject: [PATCH] doctor: check for beta XQuartz releases

Beta versions of XQuartz have address sanitization enabled, which
breaks some software at runtime, including wine.

Closes Homebrew/homebrew-core#2481.

Closes #459.

Signed-off-by: Misty De Meo <mistydemeo@github.com>
---
 Library/Homebrew/extend/os/mac/diagnostic.rb | 12 ++++++++++++
 Library/Homebrew/test/test_diagnostic.rb     |  5 +++++
 2 files changed, 17 insertions(+)

diff --git a/Library/Homebrew/extend/os/mac/diagnostic.rb b/Library/Homebrew/extend/os/mac/diagnostic.rb
index 37c1efdc2f..00a297d34b 100644
--- a/Library/Homebrew/extend/os/mac/diagnostic.rb
+++ b/Library/Homebrew/extend/os/mac/diagnostic.rb
@@ -312,6 +312,18 @@ module Homebrew
             https://xquartz.macosforge.org
         EOS
       end
+
+      def check_for_beta_xquartz
+        return unless MacOS::XQuartz.version.include? "beta"
+
+        <<-EOS.undent
+        The following beta release of XQuartz is installed: #{MacOS::XQuartz.version}
+
+        XQuartz beta releases include address sanitization, and do not work with
+        all software; notably, wine will not work with beta releases of XQuartz.
+        We recommend only installing stable releases of XQuartz.
+        EOS
+      end
     end
   end
 end
diff --git a/Library/Homebrew/test/test_diagnostic.rb b/Library/Homebrew/test/test_diagnostic.rb
index ef82da6dc7..0e0d110e7e 100644
--- a/Library/Homebrew/test/test_diagnostic.rb
+++ b/Library/Homebrew/test/test_diagnostic.rb
@@ -226,4 +226,9 @@ class DiagnosticChecksTest < Homebrew::TestCase
       end
     end
   end
+
+  def test_check_for_beta_xquartz
+    MacOS::XQuartz.stubs(:version).returns("2.7.10_beta2")
+    assert_match "The following beta release of XQuartz is installed: 2.7.10_beta2", @checks.check_for_beta_xquartz
+  end
 end
-- 
GitLab