class SettingsTest < ActionDispatch::IntegrationTest

  # Called before every test method runs. Can be used
  # to set up fixture information.
  def setup
    @admin = User.find_by(username: 'admin')
    login_as(@admin, scope: :user)
  end

  test 'update setting value' do
    put '/api/settings/fablab_name',
        setting: {
          value: 'Test Fablab'
        }
    assert_equal 200, response.status
    assert_equal Mime::JSON, response.content_type
    resp = json_response(response.body)
    assert_equal 'fablab_name', resp[:setting][:name]
    assert_equal 'Test Fablab', resp[:setting][:value]

    # Check record
    setting = Setting.find_by_name(resp[:setting][:name])
    assert_not_nil setting, 'setting was not found in database'
    assert_equal 2, setting.history_values.count, 'all historical values were not found'
    assert_includes setting.history_values.map(&:value), 'Fab Lab de La Casemate', 'previous parameter was not saved'
    assert_includes setting.history_values.map(&:value), 'Test Fablab', 'current parameter was not saved'
  end


  test 'update setting with wrong name' do
    put '/api/settings/does_not_exists',
        setting: {
          value: 'ERROR EXPECTED'
        }
    assert_equal 422, response.status
    assert_match /Name is not included in the list/, response.body
  end

  test 'show setting' do
    get '/api/settings/fablab_name'

    assert_equal 200, response.status
    assert_equal Mime::JSON, response.content_type
    resp = json_response(response.body)
    assert_equal 'fablab_name', resp[:setting][:name], 'wrong parameter name'
    assert_equal 'Fab Lab de La Casemate', resp[:setting][:value], 'wrong parameter value'
  end

end