diff options
| author | Noel Peden <[email protected]> | 2021-02-17 07:32:55 -0800 |
|---|---|---|
| committer | GitHub <[email protected]> | 2021-02-17 07:32:55 -0800 |
| commit | 4183e0b6ba69f4c1f7ea005e5e0c73537e125201 (patch) | |
| tree | 96eca1b18752b942832162392d908abf86ac8dee /test | |
| parent | 28e4870d0a108568d53fda55e1e87b34c1bdb658 (diff) | |
| parent | 9968a88579525231d6f3147ee792076ef037463a (diff) | |
| download | caxlsx-4183e0b6ba69f4c1f7ea005e5e0c73537e125201.tar.gz caxlsx-4183e0b6ba69f4c1f7ea005e5e0c73537e125201.zip | |
Merge pull request #57 from rylwin/change-serialize-signature
Deprecate using `#serialize` with boolean argument
Diffstat (limited to 'test')
| -rw-r--r-- | test/tc_package.rb | 56 |
1 files changed, 53 insertions, 3 deletions
diff --git a/test/tc_package.rb b/test/tc_package.rb index ac79b487..d313c2bd 100644 --- a/test/tc_package.rb +++ b/test/tc_package.rb @@ -129,25 +129,28 @@ class TestPackage < Test::Unit::TestCase def test_serialization @package.serialize(@fname) assert_zip_file_matches_package(@fname, @package) + assert_created_with_rubyzip(@fname, @package) File.delete(@fname) end def test_serialization_with_zip_command - @package.serialize(@fname, false, zip_command: "zip") + @package.serialize(@fname, zip_command: "zip") assert_zip_file_matches_package(@fname, @package) + assert_created_with_zip_command(@fname, @package) File.delete(@fname) end def test_serialization_with_zip_command_and_absolute_path fname = "#{Dir.tmpdir}/#{@fname}" - @package.serialize(fname, false, zip_command: "zip") + @package.serialize(fname, zip_command: "zip") assert_zip_file_matches_package(fname, @package) + assert_created_with_zip_command(fname, @package) File.delete(fname) end def test_serialization_with_invalid_zip_command assert_raises Axlsx::ZipCommand::ZipError do - @package.serialize(@fname, false, zip_command: "invalid_zip") + @package.serialize(@fname, zip_command: "invalid_zip") end end @@ -156,6 +159,53 @@ class TestPackage < Test::Unit::TestCase package.send(:parts).each{ |part| zf.get_entry(part[:entry]) } end + def assert_created_with_rubyzip(fname, package) + assert_equal 2098, get_mtime(fname, package).year, "XLSX files created with RubyZip have 2098 as the file mtime" + end + + def assert_created_with_zip_command(fname, package) + assert_equal Time.now.utc.year, get_mtime(fname, package).year, "XLSX files created with a zip command have the current year as the file mtime" + end + + def get_mtime(fname, package) + zf = Zip::File.open(fname) + part = package.send(:parts).first + entry = zf.get_entry(part[:entry]) + entry.mtime.utc + end + + def test_serialization_with_deprecated_argument + warnings = capture_warnings do + @package.serialize(@fname, false) + end + assert_equal 1, warnings.size + assert_includes warnings.first, "confirm_valid as a boolean is deprecated" + File.delete(@fname) + end + + def test_serialization_with_deprecated_three_arguments + warnings = capture_warnings do + @package.serialize(@fname, true, zip_command: "zip") + end + assert_zip_file_matches_package(@fname, @package) + assert_created_with_zip_command(@fname, @package) + assert_equal 2, warnings.size + assert_includes warnings.first, "with 3 arguments is deprecated" + File.delete(@fname) + end + + def capture_warnings(&block) + original_warn = Kernel.instance_method(:warn) + warnings = [] + Kernel.send(:define_method, :warn) { |string| warnings << string } + block.call + original_verbose = $VERBOSE + $VERBOSE = nil + Kernel.send(:define_method, :warn, original_warn) + $VERBOSE = original_verbose + warnings + end + # See comment for Package#zip_entry_for_part def test_serialization_creates_identical_files_at_any_time_if_created_at_is_set @package.core.created = Time.now |
