|
|
3aa0f2 |
From 091459248d3ce814e10d50cc4421f0c0454ef61f Mon Sep 17 00:00:00 2001
|
|
|
3aa0f2 |
From: "Bernhard M. Wiedemann" <bwiedemann@suse.de>
|
|
|
3aa0f2 |
Date: Sun, 30 Apr 2017 22:47:40 +0200
|
|
|
3aa0f2 |
Subject: [PATCH 1/4] created.rid: use SOURCE_DATE_EPOCH
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
use SOURCE_DATE_EPOCH instead of current time in created.rid top line
|
|
|
3aa0f2 |
to enable reproducible builds of ruby docs
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
See https://reproducible-builds.org/ for why this is good
|
|
|
3aa0f2 |
and https://reproducible-builds.org/specs/source-date-epoch/
|
|
|
3aa0f2 |
for the definition of this variable.
|
|
|
3aa0f2 |
---
|
|
|
3aa0f2 |
lib/rdoc/rdoc.rb | 3 +++
|
|
|
3aa0f2 |
1 file changed, 3 insertions(+)
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
diff --git a/lib/rdoc/rdoc.rb b/lib/rdoc/rdoc.rb
|
|
|
3aa0f2 |
index 68775c8be1..a2711fbbd1 100644
|
|
|
3aa0f2 |
--- a/lib/rdoc/rdoc.rb
|
|
|
3aa0f2 |
+++ b/lib/rdoc/rdoc.rb
|
|
|
3aa0f2 |
@@ -232,6 +232,9 @@ def store= store
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
def update_output_dir(op_dir, time, last = {})
|
|
|
3aa0f2 |
return if @options.dry_run or not @options.update_output_dir
|
|
|
3aa0f2 |
+ unless ENV['SOURCE_DATE_EPOCH'].nil?
|
|
|
3aa0f2 |
+ time = Time.at(ENV['SOURCE_DATE_EPOCH'].to_i).gmtime
|
|
|
3aa0f2 |
+ end
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
open output_flag_file(op_dir), "w" do |f|
|
|
|
3aa0f2 |
f.puts time.rfc2822
|
|
|
3aa0f2 |
--
|
|
|
3aa0f2 |
2.21.0
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
From 73a935e9fa63b056ea0be69c0c923afdfb4d88da Mon Sep 17 00:00:00 2001
|
|
|
3aa0f2 |
From: "Bernhard M. Wiedemann" <bwiedemann@suse.de>
|
|
|
3aa0f2 |
Date: Thu, 14 Dec 2017 10:54:54 +0100
|
|
|
3aa0f2 |
Subject: [PATCH 2/4] Do not store current timestamps in gz headers
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
to enable reproducible builds of rdoc
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
Normally, 0 would be the preferred value to indicate "no date"
|
|
|
3aa0f2 |
but that value is handled differently in Zlib::GzipWriter
|
|
|
3aa0f2 |
to put in the current time
|
|
|
3aa0f2 |
---
|
|
|
3aa0f2 |
lib/rdoc/generator/json_index.rb | 4 ++--
|
|
|
3aa0f2 |
1 file changed, 2 insertions(+), 2 deletions(-)
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
diff --git a/lib/rdoc/generator/json_index.rb b/lib/rdoc/generator/json_index.rb
|
|
|
3aa0f2 |
index e4cfe967c6..a059a5d4d0 100644
|
|
|
3aa0f2 |
--- a/lib/rdoc/generator/json_index.rb
|
|
|
3aa0f2 |
+++ b/lib/rdoc/generator/json_index.rb
|
|
|
3aa0f2 |
@@ -175,7 +175,7 @@ def generate_gzipped
|
|
|
3aa0f2 |
debug_msg "Writing gzipped search index to %s" % outfile
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
Zlib::GzipWriter.open(outfile) do |gz|
|
|
|
3aa0f2 |
- gz.mtime = File.mtime(search_index_file)
|
|
|
3aa0f2 |
+ gz.mtime = 1 # make output reproducible
|
|
|
3aa0f2 |
gz.orig_name = search_index_file.basename.to_s
|
|
|
3aa0f2 |
gz.write search_index
|
|
|
3aa0f2 |
gz.close
|
|
|
3aa0f2 |
@@ -193,7 +193,7 @@ def generate_gzipped
|
|
|
3aa0f2 |
debug_msg "Writing gzipped file to %s" % outfile
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
Zlib::GzipWriter.open(outfile) do |gz|
|
|
|
3aa0f2 |
- gz.mtime = File.mtime(dest)
|
|
|
3aa0f2 |
+ gz.mtime = 1 # make output reproducible
|
|
|
3aa0f2 |
gz.orig_name = dest.basename.to_s
|
|
|
3aa0f2 |
gz.write data
|
|
|
3aa0f2 |
gz.close
|
|
|
3aa0f2 |
--
|
|
|
3aa0f2 |
2.21.0
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
From 1b34b337b72918e83c3b952eed6998ad47974960 Mon Sep 17 00:00:00 2001
|
|
|
3aa0f2 |
From: aycabta <aycabta@gmail.com>
|
|
|
3aa0f2 |
Date: Sat, 27 Jan 2018 14:37:42 +0900
|
|
|
3aa0f2 |
Subject: [PATCH 3/4] Improve reproducible builds for .js and .js.gz files
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
The mtime for search_index.js.gz should be updated because it's
|
|
|
3aa0f2 |
generated dynamically. So uses SOURCE_DATE_EPOCH after
|
|
|
3aa0f2 |
RDoc::Generator::JsonIndex#generate creates index file.
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
FileUtils.install in RDoc::Generator::JsonIndex#generate with :preserve
|
|
|
3aa0f2 |
option because the mtime value is based on original .js file.
|
|
|
3aa0f2 |
---
|
|
|
3aa0f2 |
lib/rdoc/generator/json_index.rb | 9 +++++---
|
|
|
3aa0f2 |
test/rdoc/test_rdoc_generator_json_index.rb | 25 ++++++++++++++++++++-
|
|
|
3aa0f2 |
2 files changed, 30 insertions(+), 4 deletions(-)
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
diff --git a/lib/rdoc/generator/json_index.rb b/lib/rdoc/generator/json_index.rb
|
|
|
3aa0f2 |
index a059a5d4d0..3a1000033d 100644
|
|
|
3aa0f2 |
--- a/lib/rdoc/generator/json_index.rb
|
|
|
3aa0f2 |
+++ b/lib/rdoc/generator/json_index.rb
|
|
|
3aa0f2 |
@@ -147,12 +147,15 @@ def generate
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
JSON.dump data, io, 0
|
|
|
3aa0f2 |
end
|
|
|
3aa0f2 |
+ unless ENV['SOURCE_DATE_EPOCH'].nil?
|
|
|
3aa0f2 |
+ index_file.utime index_file.atime, Time.at(ENV['SOURCE_DATE_EPOCH'].to_i).gmtime
|
|
|
3aa0f2 |
+ end
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
Dir.chdir @template_dir do
|
|
|
3aa0f2 |
Dir['**/*.js'].each do |source|
|
|
|
3aa0f2 |
dest = File.join out_dir, source
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
- FileUtils.install source, dest, :mode => 0644, :verbose => $DEBUG_RDOC
|
|
|
3aa0f2 |
+ FileUtils.install source, dest, :mode => 0644, :preserve => true, :verbose => $DEBUG_RDOC
|
|
|
3aa0f2 |
end
|
|
|
3aa0f2 |
end
|
|
|
3aa0f2 |
end
|
|
|
3aa0f2 |
@@ -175,7 +178,7 @@ def generate_gzipped
|
|
|
3aa0f2 |
debug_msg "Writing gzipped search index to %s" % outfile
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
Zlib::GzipWriter.open(outfile) do |gz|
|
|
|
3aa0f2 |
- gz.mtime = 1 # make output reproducible
|
|
|
3aa0f2 |
+ gz.mtime = File.mtime(search_index_file)
|
|
|
3aa0f2 |
gz.orig_name = search_index_file.basename.to_s
|
|
|
3aa0f2 |
gz.write search_index
|
|
|
3aa0f2 |
gz.close
|
|
|
3aa0f2 |
@@ -193,7 +196,7 @@ def generate_gzipped
|
|
|
3aa0f2 |
debug_msg "Writing gzipped file to %s" % outfile
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
Zlib::GzipWriter.open(outfile) do |gz|
|
|
|
3aa0f2 |
- gz.mtime = 1 # make output reproducible
|
|
|
3aa0f2 |
+ gz.mtime = File.mtime(dest)
|
|
|
3aa0f2 |
gz.orig_name = dest.basename.to_s
|
|
|
3aa0f2 |
gz.write data
|
|
|
3aa0f2 |
gz.close
|
|
|
3aa0f2 |
diff --git a/test/rdoc/test_rdoc_generator_json_index.rb b/test/rdoc/test_rdoc_generator_json_index.rb
|
|
|
3aa0f2 |
index 6cb5463d29..65e7f087cc 100644
|
|
|
3aa0f2 |
--- a/test/rdoc/test_rdoc_generator_json_index.rb
|
|
|
3aa0f2 |
+++ b/test/rdoc/test_rdoc_generator_json_index.rb
|
|
|
3aa0f2 |
@@ -8,7 +8,7 @@ class TestRDocGeneratorJsonIndex < RDoc::TestCase
|
|
|
3aa0f2 |
def setup
|
|
|
3aa0f2 |
super
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
- @tmpdir = File.join Dir.tmpdir, "test_rdoc_generator_darkfish_#{$$}"
|
|
|
3aa0f2 |
+ @tmpdir = Dir.mktmpdir "test_rdoc_generator_darkfish_#{$$}_"
|
|
|
3aa0f2 |
FileUtils.mkdir_p @tmpdir
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
@options = RDoc::Options.new
|
|
|
3aa0f2 |
@@ -89,12 +89,21 @@ def test_file_dir
|
|
|
3aa0f2 |
end
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
def test_generate
|
|
|
3aa0f2 |
+ now = Time.now
|
|
|
3aa0f2 |
@g.generate
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
assert_file 'js/searcher.js'
|
|
|
3aa0f2 |
assert_file 'js/navigation.js'
|
|
|
3aa0f2 |
assert_file 'js/search_index.js'
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
+ orig_file = Pathname(File.join @pwd, 'lib/rdoc/generator/template/json_index/js/navigation.js')
|
|
|
3aa0f2 |
+ generated_file = Pathname(File.join @tmpdir, 'js/navigation.js')
|
|
|
3aa0f2 |
+ assert_equal orig_file.mtime, generated_file.mtime
|
|
|
3aa0f2 |
+ assert generated_file.mtime < now, '.js files should be the same timestamp'
|
|
|
3aa0f2 |
+
|
|
|
3aa0f2 |
+ generated_search_index = Pathname(File.join @tmpdir, 'js/search_index.js')
|
|
|
3aa0f2 |
+ assert generated_search_index.mtime > (now - 1), 'search_index.js should be generated timestamp'
|
|
|
3aa0f2 |
+
|
|
|
3aa0f2 |
json = File.read 'js/search_index.js'
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
json =~ /\Avar search_data = /
|
|
|
3aa0f2 |
@@ -137,6 +146,20 @@ def test_generate
|
|
|
3aa0f2 |
assert_equal expected, index
|
|
|
3aa0f2 |
end
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
+ def test_generate_search_index_with_reproducible_builds
|
|
|
3aa0f2 |
+ backup_epoch = ENV['SOURCE_DATE_EPOCH']
|
|
|
3aa0f2 |
+ ruby_birthday = Time.parse 'Wed, 24 Feb 1993 21:00:00 +0900'
|
|
|
3aa0f2 |
+ ENV['SOURCE_DATE_EPOCH'] = ruby_birthday.to_i.to_s
|
|
|
3aa0f2 |
+
|
|
|
3aa0f2 |
+ @g.generate
|
|
|
3aa0f2 |
+
|
|
|
3aa0f2 |
+ assert_file 'js/search_index.js'
|
|
|
3aa0f2 |
+ generated_search_index = Pathname(File.join @tmpdir, 'js/search_index.js')
|
|
|
3aa0f2 |
+ assert_equal ruby_birthday, generated_search_index.mtime
|
|
|
3aa0f2 |
+
|
|
|
3aa0f2 |
+ ENV['SOURCE_DATE_EPOCH'] = backup_epoch
|
|
|
3aa0f2 |
+ end
|
|
|
3aa0f2 |
+
|
|
|
3aa0f2 |
def test_generate_gzipped
|
|
|
3aa0f2 |
begin
|
|
|
3aa0f2 |
require 'zlib'
|
|
|
3aa0f2 |
--
|
|
|
3aa0f2 |
2.21.0
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
From 74c1e201f2146e7175e74d6fc0b9386c2e95210f Mon Sep 17 00:00:00 2001
|
|
|
3aa0f2 |
From: aycabta <aycabta@gmail.com>
|
|
|
3aa0f2 |
Date: Sat, 27 Jan 2018 17:54:31 +0900
|
|
|
3aa0f2 |
Subject: [PATCH 4/4] Use dirty hack on JRuby for MiniTest 4
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
---
|
|
|
3aa0f2 |
test/rdoc/test_rdoc_generator_json_index.rb | 6 +++++-
|
|
|
3aa0f2 |
1 file changed, 5 insertions(+), 1 deletion(-)
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
diff --git a/test/rdoc/test_rdoc_generator_json_index.rb b/test/rdoc/test_rdoc_generator_json_index.rb
|
|
|
3aa0f2 |
index 65e7f087cc..714d496195 100644
|
|
|
3aa0f2 |
--- a/test/rdoc/test_rdoc_generator_json_index.rb
|
|
|
3aa0f2 |
+++ b/test/rdoc/test_rdoc_generator_json_index.rb
|
|
|
3aa0f2 |
@@ -98,7 +98,11 @@ def test_generate
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
orig_file = Pathname(File.join @pwd, 'lib/rdoc/generator/template/json_index/js/navigation.js')
|
|
|
3aa0f2 |
generated_file = Pathname(File.join @tmpdir, 'js/navigation.js')
|
|
|
3aa0f2 |
- assert_equal orig_file.mtime, generated_file.mtime
|
|
|
3aa0f2 |
+
|
|
|
3aa0f2 |
+ # This is dirty hack on JRuby for MiniTest 4
|
|
|
3aa0f2 |
+ assert orig_file.mtime.inspect == generated_file.mtime.inspect,
|
|
|
3aa0f2 |
+ '.js files should be tha same timestamp of original'
|
|
|
3aa0f2 |
+
|
|
|
3aa0f2 |
assert generated_file.mtime < now, '.js files should be the same timestamp'
|
|
|
3aa0f2 |
|
|
|
3aa0f2 |
generated_search_index = Pathname(File.join @tmpdir, 'js/search_index.js')
|
|
|
3aa0f2 |
--
|
|
|
3aa0f2 |
2.21.0
|
|
|
3aa0f2 |
|