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
100
Ecto sem SQL
lucas
0
390
Feature Toggles! - Elixir
lucas
3
590
Feature Toggles! - Ruby
lucas
2
360
Testes automatizados e a prática antes da teoria
lucas
0
410
Circuit Breakers em Ruby
lucas
1
410
The Zen and Art of Refactoring
lucas
4
960
Minitest: voltando ao básico sobre testes
lucas
1
410
10 coisas que eu gostaria de ter aprendido mais cedo
lucas
67
5.4k
Other Decks in Technology
See All in Technology
AI実装による「レビューボトルネック」を解消する仕様駆動開発(SDD)/ ai-sdd-review-bottleneck
rakus_dev
0
150
OSC仙台プレ勉強会 AlmaLinuxとは
koedoyoshida
0
190
AI時代の「本当の」ハイブリッドクラウド — エージェントが実現した、あの頃の夢
ebibibi
0
140
スクリプトの先へ!AIエージェントと組み合わせる モバイルE2Eテスト
error96num
0
180
楽しく学ぼう!ネットワーク入門
shotashiratori
1
460
Kiro Powers 入門
k_adachi_01
0
110
DevOpsエージェントで実現する!! AWS Well-Architected(W-A) を実現するシステム設計 / 20260307 Masaki Okuda
shift_evolve
PRO
3
930
複数クラスタ運用と検索の高度化:ビズリーチにおけるElastic活用事例 / ElasticON Tokyo2026
visional_engineering_and_design
0
170
アーキテクチャモダナイゼーションを実現する組織
satohjohn
1
1k
ガバメントクラウドにおけるAWSの長期継続割引について
takeda_h
2
5.1k
visionOS 開発向けの MCP / Skills をつくり続けることで XR の探究と学習を最大化
karad
1
440
ソフトバンク流!プラットフォームエンジニアリング実現へのアプローチ
sbtechnight
1
180
Featured
See All Featured
Optimising Largest Contentful Paint
csswizardry
37
3.6k
We Analyzed 250 Million AI Search Results: Here's What I Found
joshbly
1
980
How to Ace a Technical Interview
jacobian
281
24k
Writing Fast Ruby
sferik
630
63k
Noah Learner - AI + Me: how we built a GSC Bulk Export data pipeline
techseoconnect
PRO
0
140
Information Architects: The Missing Link in Design Systems
soysaucechin
0
830
Optimizing for Happiness
mojombo
378
71k
Pawsitive SEO: Lessons from My Dog (and Many Mistakes) on Thriving as a Consultant in the Age of AI
davidcarrasco
0
88
Put a Button on it: Removing Barriers to Going Fast.
kastner
60
4.2k
Marketing Yourself as an Engineer | Alaka | Gurzu
gurzu
0
150
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
35
2.4k
Facilitating Awesome Meetings
lara
57
6.8k
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