afix

Automatic software repair excercise in Crystal

afix

Automatic software repair excercise in Crystal for eci2015.

It searches for fixes adding +1/-1 to integers assignments.

They were indeed bugs that could have been solved by this technique in Crystal. This bug is ported in sample/markdown.cr

Sample1

$ crystal sample/sample1.cr
$ crystal src/instrument.cr -- sample/sample1.cr
$ crystal src/fix_finder.cr -- ./sample/sample1.afix.cr
$ patch -p1 < sample/sample1.cr.patch
$ crystal sample/sample1.cr

Markdown sample

$ crystal sample/markdown.cr
$ crystal src/instrument.cr -- sample/markdown.cr
## change markdown.afix.json for trace optimizations
$ crystal src/fix_finder.cr -- ./sample/markdown.afix.cr
$ patch -p1 < sample/markdown.cr.patch
$ crystal sample/markdown.cr

The instrumentation is greedy. It covers the whole file making the search space pretty huge. To mimic an instrumentation only on the expressions stressed on the failing test case and the following key/value to .afix.json file.

strategy time tries
naïve changes 7yrs NaN
naïve with trace hint 20min 24057
near without trace hint 40seg 333
near with trace hint 8seg 129
# markdown.afix.json with trace hint
{"i2":0,"i3":0,"i5":0,"i6":0,"ia":0,"ib":0,"ii":0,"ij":0,"ik":0,"il":0,"im":0,"i11":0,"i14":0,"i15":0,"i1d":0,"i1e":0,"i1j":0}

Trace approximation

Make the .afix.cr file start with

require "../src/monitor"
require "../src/trace"
AfixMonitor.load(ARGV[0])

Run the failing test only, extract the monitors keys, etc.

crystal spec sample/markdown.afix.cr:773 sample/markdown.afix.json | uniq | sort

Outputs

diff --git a/sample/sample1.cr b/sample/sample1.cr
index 2031d4b..d5c1e66 100644
--- a/sample/sample1.cr
+++ b/sample/sample1.cr
@@ -1,7 +1,7 @@
 require "spec"

 def succ(a)
-  res = a + 2
+  res = a + 2 - 1
   res
 end

@@ -10,3 +10,4 @@ describe "self" do
     succ(1).should eq(2)
   end
 end
diff --git a/sample/markdown.cr b/sample/markdown.cr
index 87fc0a4..dbac2de 100644
--- a/sample/markdown.cr
+++ b/sample/markdown.cr
@@ -472,8 +472,8 @@ class Markdown::Parser
           @renderer.end_link

           paren_idx = (str + pos + 1).to_slice(bytesize - pos - 1).index(')'.ord).not_nil!
-          pos += paren_idx + 2
-          cursor = pos
+          pos += paren_idx + 2 - 1
+          cursor = pos + 1
           in_link = false
         end
       end

compare to bugfix .

Repository

afix

Owner
Statistic
  • 3
  • 1
  • 0
  • 0
  • 0
  • over 9 years ago
  • July 23, 2015
License

MIT License

Links
Synced at

Tue, 21 Jan 2025 09:27:39 GMT

Languages