Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Contribuindo com projetos OpenSource: a teoria ...
Search
Lucas Mazza
October 19, 2013
Technology
14
10k
Contribuindo com projetos OpenSource: a teoria na prática.
Lucas Mazza
October 19, 2013
Tweet
Share
More Decks by Lucas Mazza
See All by Lucas Mazza
OpenAPI e Elixir (e qualquer outra linguagem)
lucas
0
67
Ecto sem SQL
lucas
0
360
Feature Toggles! - Elixir
lucas
3
500
Feature Toggles! - Ruby
lucas
2
340
Testes automatizados e a prática antes da teoria
lucas
0
400
Circuit Breakers em Ruby
lucas
1
380
The Zen and Art of Refactoring
lucas
4
800
Minitest: voltando ao básico sobre testes
lucas
1
380
10 coisas que eu gostaria de ter aprendido mais cedo
lucas
67
5.4k
Other Decks in Technology
See All in Technology
要件定義・デザインフェーズでもAIを活用して、コミュニケーションの密度を高める
kazukihayase
0
120
Evolución del razonamiento matemático de GPT-4.1 a GPT-5 - Data Aventura Summit 2025 & VSCode DevDays
lauchacarro
0
210
【NoMapsTECH 2025】AI Edge Computing Workshop
akit37
0
230
人工衛星のファームウェアをRustで書く理由
koba789
15
8.3k
COVESA VSSによる車両データモデルの標準化とAWS IoT FleetWiseの活用
osawa
1
400
まずはマネコンでちゃちゃっと作ってから、それをCDKにしてみよか。
yamada_r
2
120
データ分析エージェント Socrates の育て方
na0
8
2.7k
組織を巻き込む大規模プラットフォーム移行戦略 〜50+サービスのマルチリージョン・マルチプロダクト化で学んだステークホルダー協働の実践〜 / Platform migration strategy engaging all stakeholders
toshi0607
2
200
dbt開発 with Claude Codeのためのガードレール設計
10xinc
2
1.3k
スクラムガイドに載っていないスクラムのはじめかた - チームでスクラムをはじめるときに知っておきたい勘所を集めてみました! - / How to start Scrum that is not written in the Scrum Guide 2nd
takaking22
2
210
RSCの時代にReactとフレームワークの境界を探る
uhyo
11
3.5k
slog.Handlerのよくある実装ミス
sakiengineer
4
480
Featured
See All Featured
How GitHub (no longer) Works
holman
315
140k
jQuery: Nuts, Bolts and Bling
dougneiner
64
7.9k
Agile that works and the tools we love
rasmusluckow
330
21k
Intergalactic Javascript Robots from Outer Space
tanoku
272
27k
Embracing the Ebb and Flow
colly
87
4.8k
Distributed Sagas: A Protocol for Coordinating Microservices
caitiem20
333
22k
Bootstrapping a Software Product
garrettdimon
PRO
307
110k
Testing 201, or: Great Expectations
jmmastey
45
7.7k
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
162
15k
The Cult of Friendly URLs
andyhume
79
6.6k
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
656
61k
Six Lessons from altMBA
skipperchong
28
4k
Transcript
Contribuindo com projetos OpenSource a teoria na prática
@lucasmazza
http:/ /www.casadocodigo.com.br/products/livro-html-css
None
Open Source wat?
None
Open Source
Open Source Você
OSS Ruby Ruby on Rails jQuery Redis Git Django Bootstrap
Backbone Node.JS Debian PHP Elixir MySQL Java Android AngularJS Docker MongoDB H5BP Android Play
Open Source não é trabalhar de graça
Open Source não é uma competição
Open Source é sobre cultura
Colaboração Comunicação Aprendizado
Desenvolvedores ajudando desenvolvedores
(Obrigado GitHub <3)
Participando dos projetos você pode aprender muito sobre o código
que você usa no seu dia a dia
Como as coisas funcionam
Como as coisas funcionam Design de APIs
Como as coisas funcionam Design de APIs Performance
Como as coisas funcionam Design de APIs Performance Como fazer
software melhor
Ler o código existente é uma bagagem incrível
Você pode ajudar a definir o rumo da comunidade
E dos projetos que são importantes para você
E o importante é começar a participar
“Dude, sucking at something is the first step towards being
sorta good at something.”
como faz?
Reportando bugs
Reportando bugs Enviando patches
Reportando bugs Enviando patches Participando de discussões
Reportando bugs Enviando patches Participando de discussões Revisando colaborações
Todo mundo começa reportando bugs
Confira as issues existentes
Confira as issues existentes StackOverflow e mailing lists
Confira as issues existentes StackOverflow e mailing lists Explique como
reproduzir o bug
Confira as issues existentes StackOverflow e mailing lists Explique como
reproduzir o bug Stacktraces, versões e tudo mais
Não reporte falhas de segurança publicamente
[email protected]
[email protected]
[email protected]
Aprenda as regras de cada projeto
None
Contributing to Ghost 1. Reporting An Issue 2. Working on
Ghost Core 3. Coding standards 4. Submitting Pull Requests 5. Grunt Toolkit 6. Troubleshooting / FAQ 7. Contributor License Agreement CONTRIBUTING.md @ TryGhost/Ghost
twbs/bootstrap joyent/node rails/rails jashkenas/backbone plataformatec/devise
Triagem de issues e test drive de correções
None
None
None
None
None
None
None
o papel de “suporte” é muito importante
Detalhes de configuração
Detalhes de configuração APIs alternativas
Detalhes de configuração APIs alternativas Issues duplicadas
Detalhes de configuração APIs alternativas Issues duplicadas Benchmarks das suas
apps
Tente corrigir sozinho e envie um Pull Request
$ git clone https://github.com/voce/repo.git $ git checkout -b fix-things #
hack hack hack hack hack $ rake test # Pull Request time! $ git commit $ git push origin fix-things -u
None
Busque opiniões sobre o código
Busque opiniões sobre o código merge / rebase / squash
a vontade
Busque opiniões sobre o código merge / rebase / squash
a vontade Tome o seu tempo para acabar
Busque opiniões sobre o código merge / rebase / squash
a vontade Tome o seu tempo para acabar Repita tudo de novo
Feedback é a maior recompensa que você pode receber em
um Pull Request
“[...] Remember that a PR is the start of a
conversation, not the end of one.” CONTRIBUTING.md @ boxen/puppet-git
“Build First, Discuss Later” Mark McSpadden @ Your First Rails
Pull Request
https:/ /help.github.com/articles/using-pull-requests
http:/ /guidelines.plataformatec.com.br/pull-requests
Nem tudo é sobre escrever código
Documentação e guias
Wikis
Typos, warnings e código obsoleto
rails/docrails github/developer.github.com janl/waaa
não se esqueça
Não existe contribuição “pequena demais”
None
Existe um zilhão de formas de participar
None
Não tenha medo de pedir ajuda
None
Colocando o seu código no mundo
“Porque eu colocaria o meu código no GitHub?”
Manter o seu código para o futuro
Manter o seu código para o futuro Receber ajuda de
outros devs
Manter o seu código para o futuro Receber ajuda de
outros devs Vale mais que o seu LinkedIn
None
1 Escolha uma licença
“Choosing a n OSS license doesn’t need to be scary”
http:/ /choosealicense.com
“Choosing a n OSS license doesn’t need to be scary”
http:/ /choosealicense.com TL;DR: Apache 2.0 ou MIT
2 Escreva um README
Readme Driven Development - @mojombo “Consider the process of writing
the Readme for your project as the true act of creation.”
3 Escreva o seu código
Dave Thomas @ elixir-lang-core “[...]In the meantime, the only truth
is code.”
Faça ser fácil contribuir com o seu projeto
O que eu preciso instalar?
O que eu preciso instalar? Como eu testo o que
eu fiz?
O que eu preciso instalar? Como eu testo o que
eu fiz? Qual o workflow do projeto?
Cuide do seu README.md e CONTRIBUTING.md
Abuse do ferramental da comunidade
Automatize as partes mecânicas
source 'https://rubygems.org' gemspec gem 'country_select', '~> 1.1.1' gem 'railties', '>=
4.0.0', '< 4.1' gem 'activemodel', '>= 4.0.0', '< 4.1' gem 'actionpack', '>= 4.0.0', '< 4.1' gem 'rake' gem 'rdoc' gem 'tzinfo' Bundler
Travis CI
Documentação
Vagrant Boxes
WebHooks
Dedique um tempo para revisar as contribuições
E ajude os outros a melhorar o seu software
Retrocompatibilidade
Retrocompatibilidade APIS e styleguides
Retrocompatibilidade APIS e styleguides Promova contribuidores
Retrocompatibilidade APIS e styleguides Promova contribuidores Lidere por exemplo
Não tenha medo de começar de novo
None
“I have learned that in the open- source world, you
are not your code. A critique of your project is not tantamount to a personal attack.” http:/ /sstephenson.us/posts/you-are-not-your-code
Open Source e código fechado
Open Source é baseado em:
Colaboração
Colaboração Comunicação
Colaboração Comunicação Aprendizado
Desenvolvimento de Sofware é baseado em:
Colaboração
Colaboração Comunicação
Colaboração Comunicação Aprendizado
O que funciona de um lado pode funcionar do outro
Descentralização
Descentralização Visibilidade do que é feito
Descentralização Visibilidade do que é feito Comunicação aberta
Descentralização Visibilidade do que é feito Comunicação aberta Autoria coletiva
“Your team should work like an open source project.” http:/
/tomayko.com/writings/adopt-an-open-source-process-constraints
Obrigado! https:/ /twitter.com/lucasmazza https:/ /speakerdeck.com/lucas