Parâmetros nomeados em Ruby 2

Eu não entendo completamente como os parâmetros nomeados no Ruby 2.0 funcionam.

def test(var1, var2, var3)
  puts "#{var1} #{var2} #{var3}"
end

test(var3:"var3-new", var1: 1111, var2: 2222) #wrong number of arguments (1 for 3) (ArgumentError)

é tratado como um hash. E é muito engraçado porque usar parâmetros nomeados no Ruby 2.0 Idevo defina valores padrão para eles:

def test(var1: "var1", var2: "var2", var3: "var3")
  puts "#{var1} #{var2} #{var3}"
end

test(var3:"var3-new", var1: 1111, var2: 2222) # ok => 1111 2222 var3-new

que muito semelhante ao comportamento que Ruby tinha antes com os valores dos parâmetros padrão:

def test(var1="var1", var2="var2", var3="var3")
  puts "#{var1} #{var2} #{var3}"
end

test(var3:"var3-new", var1: 1111, var2: 2222) # ok but ... {:var3=>"var3-new", :var1=>1111, :var2=>2222} var2 var3

Eu sei porque isso está acontecendo e quase como funciona.

Mas estou apenas curiosodevo Eu uso valores padrão para parâmetros se eu usar parâmetros nomeados?

E alguém pode me dizer qual é a diferença entre esses dois?

def test1(var1="default value123")
  #.......
end

def test1(var1:"default value123")
  #.......
end

questionAnswers(8)

yourAnswerToTheQuestion