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
70
Ecto sem SQL
lucas
0
370
Feature Toggles! - Elixir
lucas
3
510
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
830
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
Dify on AWS 環境構築手順
yosse95ai
0
150
ゼロコード計装導入後のカスタム計装でさらに可観測性を高めよう
sansantech
PRO
1
500
あなたの知らない Linuxカーネル脆弱性の世界
recruitengineers
PRO
3
160
GraphRAG グラフDBを使ったLLM生成(自作漫画DBを用いた具体例を用いて)
seaturt1e
1
150
コンパウンド組織のCRE #cre_meetup
layerx
PRO
1
280
Zero Trust DNS でより安全なインターネット アクセス
murachiakira
0
110
From Natural Language to K8s Operations: The MCP Architecture and Practice of kubectl-ai
appleboy
0
270
ストレージエンジニアの仕事と、近年の計算機について / 第58回 情報科学若手の会
pfn
PRO
3
870
AWS DMS で SQL Server を移行してみた/aws-dms-sql-server-migration
emiki
0
250
オブザーバビリティが育むシステム理解と好奇心
maruloop
3
1.4k
SRE × マネジメントレイヤーが挑戦した組織・会社のオブザーバビリティ改革 ― ビジネス価値と信頼性を両立するリアルな挑戦
coconala_engineer
0
280
AI機能プロジェクト炎上の 3つのしくじりと学び
nakawai
0
120
Featured
See All Featured
Embracing the Ebb and Flow
colly
88
4.9k
The Straight Up "How To Draw Better" Workshop
denniskardys
238
140k
Building Better People: How to give real-time feedback that sticks.
wjessup
369
20k
Performance Is Good for Brains [We Love Speed 2024]
tammyeverts
12
1.2k
The Language of Interfaces
destraynor
162
25k
The MySQL Ecosystem @ GitHub 2015
samlambert
251
13k
Automating Front-end Workflow
addyosmani
1371
200k
Bootstrapping a Software Product
garrettdimon
PRO
307
110k
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
31
9.7k
KATA
mclloyd
PRO
32
15k
The Psychology of Web Performance [Beyond Tellerrand 2023]
tammyeverts
49
3.1k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
30
2.9k
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