Нам нужны твои мозги

Хотите расти как разработчик и найти крутую работу? Не протирайте штаны — займитесь Open Source проектами. Так легче всего попасть в лучшие команды разработчиков и положить себе в резюме настоящий проект, вместо нелепых «примеров кода». Но найти подходящий проект для участия сложно. Начинаются лень и отговорки, а за ними — отсутствие профессионального роста, критики по-настоящему крутых программистов, уныние и застой.

На Cult of Martians мы собираем интересные задачи для современных веб-программистов. Можно выбрать подходящую по сложности, продолжительности и специализации. Задачи не выдуманы «из воздуха» — каждая решает насущную проблему, и решить ее можно через создание нового Open Source проекта или улучшение существующего. Решайте задачи, прокачивайтесь, присылайте решение на оценку. Лучших могут пригласить к себе на работу компании, программистам которых понравится ваше решение.

Бэк: Добавить поддержку #read_multi в Ruby gem graphql-ruby-fragment_cache

Для уверенных в себе, задача на неделю

graphql-ruby-fragment_cache — Ruby gem, позволяющий кэшировать части ответа на GraphQL запрос.

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

Польза: разобраться с устройством graphql-ruby, прокачаться в Ruby, принести пользу сообществу.

Постановка задачи

Для примера рассмотрим схему, которая позволяет получить данные публикации по ее ID:

class PostType < BaseObject
  field :id, ID, null: false
  field :title, String, null: false
end

class QueryType < BaseObject
  field :post, PostType, null: true, cache_fragment: true do
    argument :id, ID, required: true
  end

  def post(id:)
    Post.find(id)
  end
end

Для того, чтобы произошло два обращения к кэшу, достаточно сделать подобный запрос:

query {
  post1: post(id: 1) {
    id
    title
  }

  post2: post(id: 2) {
    id
    title
  }
}

Необходимо сделать так, чтобы эти запросы были объединены в один и обращение к хранилищу произошло только один раз.

Советы по реализации

  1. Сначала стоит придумать механизм объединения нескольких запросов в один.
  2. Библиотека может работать с разными хранилищами, и не все из них поддерживают #read_multi, нужно подумать, как работать и с ними тоже.

Инструкции по выполнению

  1. Обсудить задачу, если есть вопросы.
  2. Форкнуть проект graphql-ruby-fragment_cache на GitHub.
  3. Реализовать необходимый функционал, покрыть его тестами и задокументировать.
  4. Сделать Pull Request.