require 'spec_helper'

describe ParallelTests::Test::RuntimeLogger do
  def sh(command)
    result = `#{command} 2>&1`
    raise "FAILED: #{result}" unless $?.success?
  end

  def run_tests
    sh "ruby #{Bundler.root}/bin/parallel_test test -n 2"
  end

  it "writes a correct log on minitest-5" do
    skip if RUBY_PLATFORM == "java" # just too slow ...
    use_temporary_directory do
      # setup simple structure
      FileUtils.mkdir "test"
      2.times do |i|
        File.write("test/#{i}_test.rb", <<-RUBY)
          require 'minitest/autorun'
          require 'parallel_tests/test/runtime_logger'

          class Foo#{i} < Minitest::Test
            def test_foo
              sleep 0.5
              assert true
            end
          end

          class Bar#{i} < Minitest::Test
            def test_foo
              sleep 0.25111
              assert true
            end
          end
        RUBY
      end

      run_tests

      # log looking good ?
      lines = File.read("tmp/parallel_runtime_test.log").split("\n").sort.map { |x| x.sub(/\d$/, "") }
      expect(lines).to eq([
        "test/0_test.rb:0.7",
        "test/1_test.rb:0.7",
      ])
    end
  end
end
