Подтвердить что ты не робот

Есть ли дополнительный ключ/ответ для рубиновых коанов?

Недавно я попробовал заострить свои навыки рельсов с помощью этого инструмента:

http://github.com/edgecase/ruby_koans

но я испытываю трудности с прохождением некоторых тестов. Также я не уверен, правильно ли я делаю что-то, потому что цель - просто пройти тест, есть много способов передать это, и я могу делать что-то, что не соответствует стандартам.

Есть ли способ подтвердить, правильно ли я делаю?

конкретный пример:

в about_nil,

 def test_nil_is_an_object
   assert_equal __, nil.is_a?(Object), "Unlike NULL in other languages"
 end

так он говорит мне проверить, равно ли это второе предложение объекту (так что я могу сказать, что nil - это объект) или просто поместите assert_equal true, nil.is_a?(Object), потому что утверждение верно?

и следующего теста:

def test_you_dont_get_null_pointer_errors_when_calling_methods_on_nil
  # What happens when you call a method that doesn't exist.  The
  # following begin/rescue/end code block captures the exception and
  # make some assertions about it.
  begin
    nil.some_method_nil_doesnt_know_about
  rescue Exception => ex
    # What exception has been caught?
    assert_equal __, ex.class

    # What message was attached to the exception?
    # (HINT: replace __ with part of the error message.)
    assert_match(/__/, ex.message)
  end
end

Я предполагаю, что в файле assert_match я должен поместить строку "No method error", но как насчет assert_equal? ​​

4b9b3361

Ответ 1

assert_equal true, nil.is_a?(Object) действительно является правильным решением. Возникает вопрос: "Нуль в Ruby-объектах или нет?", А в случае с Ruby они есть. Таким образом, чтобы передать утверждение, вы должны утверждать правду этого теста.

Во втором примере, когда вы вызываете метод undefined на nil, вы получаете NoMethodError: undefined method 'foo' for nil:NilClass. Таким образом, класс исключения NoMethodError, а сообщение undefined method 'foo' for nil:NilClass. Проверьте поведение сбоев в консоли и посмотрите, что вы получаете от него, а затем примените это знание к тесту.

Ответ 2

Вы используете

ruby path_to_enlightenment.rb

в командной строке после исправления каждого теста? Это даст вам много помощи.

Также "помните, что молчание иногда является лучшим ответом" - если вы в тупике, не вкладывайте ничего, и инструмент вам поможет.

Ответ 3

Хорошо, держась за типичный TDD-девиз Red-Green-Refactor, вы должны запустить тест (возможно, с граблями в отдельной консоли) и увидеть, что произошел сбой. Оттуда они предоставили вам несколько информации о том, что ожидалось.

Что касается стиля, коаны на самом деле не учат этому. Вы должны просто найти и прочитать код, написанный на рубине, чтобы почувствовать типичные соглашения и идиомы сообщества рубинов.

Ответ 4

Простота - ключ к Ruby Koans - когда я начал, я думал, что это должно быть сложнее, чем это, но это не так! Просто спросите IRB вопрос, который Коанс задает вам, и после нескольких вы почувствуете это. Я написал часть блога об этом, чтобы помочь другим:

Ruby Koans Answers

Ответ 5

Я помню, когда я это делал, я пытался опробовать тест и попытался включить

<Answer> and <"Answer">

Следует помнить, что фактический класс не обязательно должен быть в строке или что-то в этом роде. Поэтому ответ НЕ

ex.class, ex.class

Как было сказано выше, введите код в irb и выполните его.

(1..5).class == Range

- большой намек