SlideShare ist ein Scribd-Unternehmen logo
1 von 34
Downloaden Sie, um offline zu lesen
Quanto isso pode ajudar?
ARQUITETURA EM CAMADAS
EM PYTHON
ITENS QUE VEREMOS SOBRE ESSE ASSUNTO
⇝ O que é arquitetura em camadas;
⇝ Pensar em camadas ainda é importante?
⇝ Aplicando uso de camadas em Python;
⇝ Padrões de projetos, como eles ajudam a ter camadas;
⇝ Quais vantagens e desvantagens?
⇝ Um caso real do uso de camadas.
o que é
arquitetura
em camadas ?
É UM ESTILO ARQUITETURAL
QUE PROPÕE DIVIDIR UM
SISTEMA EM VÁRIAS
CAMADAS DE ACORDO COM
A RESPONSABILIDADE DE
CADA PARTE DO SOFTWARE.
ESSE ESTILO PROPÕE QUE:
⇝ AS CAMADAS TENHAM UM
PROPÓSITO BEM DEFINIDO;
⇝ CADA CAMADA CONHEÇA APENAS
CAMADAS ABAIXO DELA;
⇝ AS CAMADAS POSSAM SER
REAPROVEITÁVEIS.
UM DESENHO TRADICIONAL DE CAMADAS...
O USO DE CAMADAS EM
SOFTWARE GANHOU FORÇA
NA DÉCADA DE 90, COM USO
DE 2 CAMADAS.
LOGO DEPOIS GANHOU MAIS
POPULARIDADE COM O USO
DE 3 CAMADAS.
O CONCEITO NÃO NASCEU
NO MUNDO DE SOFTWARE,
OUTRAS ÁREAS O USAM HÁ
MUITO TEMPO!
E NO MUNDO DE SOFTWARE
ELE TAMBÉM É APLICADO HÁ
MAIS TEMPO DO QUE
PARECE.
MODELO OSI SISTEMAS
OPERACIONAIS
DOCKER
E…
NA MINHA APLICAÇÃO
PENSAR EM CAMADAS
AINDA É
IMPORTANTE?
⇝ MESMO COM ARQUITETURA
ORIENTADA A SERVIÇOS?
⇝ MESMO COM MICRO-SERVIÇOS ?
⇝ MESMO COM CLOUD?
DEVEMOS AINDA TER QUE
PENSAR EM CAMADAS?
SIM !!!
VOCÊ PODE NÃO SABER OU ATÉ NÃO QUERER,
MAS GERALMENTE SUA APLICAÇÃO ESTÁ EM CAMADAS !!!
WEB
APP
MOBILE
APP
DATABASE
CONTROLLERS
REST
DOMAIN
SERVICE
REPOSITORY
MODEL
RELATIONAL NOSQL
EXTERNAL SERVICES
REST
SERVICES
MESSAGE
QUEUE
OTHERS
FRONT BACK
E COMO POSSO APLICAR
CAMADAS EM PYTHON ?
VAMOS USAR UM EXEMPLO !.
apenas backend .
Um projeto simples, chamado:
Quotes Box
(Caixinha de Citações)
que usa os frameworks:
Flask e SQLAlchemy
Telas administrativas...
API Rest...
O projeto tem...
O projeto começa pequeno.
Mas, o projeto cresce um pouco...
E... o projeto cresce mais ainda...
o projeto é dividido em camadas!
O fonte é dividido em vários arquivos .py...
pronto, o projeto está usando
arquitetura em camadas !!!
só que não ! E PORQUE ?
novos recursos são necessários…
⇝ Executar processos agendados (cron);
⇝ Suportar volume alto de requisições;
⇝ Trabalhar com outros bancos de dados;
dificuldades na implementação surgem…
⇝ Com mais desenvolvedores há conflitos na codificação;
⇝ Fazer testes está cada vez mais difícil;
⇝ ...
eu consigo ____ ?
⇝ Executar rotinas de negócio sem usar API rest...
⇝ Trocar de forma fácil meu framework que expõe rest...
⇝ Optar por salvar os dados em nosql ou relacional...
⇝ Aplicar testes a partes específicas de forma simples...
⇝ Dividir o trabalho entre o time sem gerar conflito...
⇝ Evoluir o sistema sem precisar refatorar tudo...
e.. diante disso, nos perguntamos:
o que pode ser feito para
realmente usar camadas no
projeto?
Comece separando em pacotes, representando as camadas.
Projeto Único
quote-box-core==1.0.0
Projeto Core Projeto App
Ou
Tenha cuidado com dependência entre camadas
Camada domain não
deveria conhecer coisas da
camada acima
Usando apenas SQLAlchemy
⇝ A falta de tipagem facilita esperar atributos da camada de
cima que não fazem parte do modelo da camada em questão;
⇝ Métodos decorrentes de necessidades da camada de cima,
como: to_json(), json();
⇝ Camadas esperando variáveis de ambiente definidas na
camada de cima;
⇝ Tipo de dados específico de um bancos de dados.
e... o que mais precisamos ter atençao?
⇝ Camadas que serão usadas como bibliotecas, é melhor
usar objetos como estrutura de dados e evitar dicionários;
⇝ Frameworks que “geram tudo” mas não em camadas, ou
organizado em camadas mas com dependências implícitas
entre uma camada e a camada acima.
⇝ Não confiar apenas nos “olhos”, usar ferramentas que
validem a arquitetura. Ex.: Structure101.
precisamos ter atençao também em...
E… o que podemos estudar para
trabalhar corretamente com camadas?
princípios de
orientação a objetos
e
PADRÕES DE PROJETO
quais deles podem me ajudar?
⇝ Princípios SOLID;
⇝ Padrões GoF;
⇝ Padrões GRASP;
⇝ Padrão MVC;
CAMADAS SÓ
SE APLICAM
A SOLUÇÕES COM
BACKEND/FRONTEND?
Não !...
DOMAINCONTROLLER
JSON
YAML
LINE
ARGUMENTS
EXTERNAL
CLIENTS
APP DE DEPLOY EXECUTADA VIA
LINHA DE COMANDO.
TODA SOLUÇÃO
DEVERIA SER
ARQUITETADA EM
CAMADAS?
Não !...
Isso não é uma regra,
esse estilo não resolve
todos seus problemas,
mas geralmente ajuda!
Entenda bem o
negócio e o momento
do projeto!
QUAIS VANTAGENS?
⇝ Maior organização do código;
⇝ Código mais testável;
⇝ Software modularizado;
⇝ Divisão de responsabilidade;
⇝ Maior adaptabilidade;
⇝ Maior reusabilidade;
⇝ Maior escalabilidade.
E DESVANTAGENS?
⇝ Maior número de Classes;
⇝ Maior complexidade na
execução do sistema;
⇝ Menos performance
dependendo da forma de
comunicação entre as camadas;
⇝ Maior complexidade no
versionamento;
⇝ Requer maior conhecimento e
maturidade do desenvolvedor.
COMO O USO DE CAMADAS AJUDA NA
CONSTRUÇÃO DE SOLUÇÕES CORPORATIVAS
NA NEXXERA.
DOMAIN
SERVICE
REPOSITORY
MODEL
(WEB)
CONTROLLER
REST
DATABASES
SOLUÇÃO FINANCEIRA,
PAGAMENTOS BANCÁRIOS
(CONSOLE)
CONTROLLER
TEXT/PLAIN
FILE
EXTERNAL
SERVICES
RELACIONAL
www.nexxera.com
OBRIGADO A TODOS!
isaacsouza@gmail.com
Projeto exemplo em:
https://gitlab.com/betterdeveloper-examples/
quotes-box-layers
Slides em:
https://pt.slideshare.net/betterdeveloper
www.betterdeveloper.net
PERGUNTAS?
BONS LIVROS QUE AJUDAM NO ASSUNTO...
agile software
development,
principles,
patterns and pratices

Weitere ähnliche Inhalte

Was ist angesagt?

Padroes De Projeto
Padroes De ProjetoPadroes De Projeto
Padroes De Projeto
ejdn1
 
Java introdução ao java
Java   introdução ao javaJava   introdução ao java
Java introdução ao java
Armando Daniel
 
Introdução sobre desenvolvimento web
Introdução sobre desenvolvimento webIntrodução sobre desenvolvimento web
Introdução sobre desenvolvimento web
Rodrigo Rodrigues
 

Was ist angesagt? (20)

Padroes De Projeto
Padroes De ProjetoPadroes De Projeto
Padroes De Projeto
 
Conhecendo o Django
Conhecendo o DjangoConhecendo o Django
Conhecendo o Django
 
COMO EXECUTAR SCRIPT PYTHON com JS
COMO EXECUTAR SCRIPT PYTHON com JSCOMO EXECUTAR SCRIPT PYTHON com JS
COMO EXECUTAR SCRIPT PYTHON com JS
 
Frameworks de desenvolvimento web
Frameworks de desenvolvimento webFrameworks de desenvolvimento web
Frameworks de desenvolvimento web
 
Desvendando a linguagem JavaScript
Desvendando a linguagem JavaScriptDesvendando a linguagem JavaScript
Desvendando a linguagem JavaScript
 
Metodologias de Desenvolvimento de Software
Metodologias de Desenvolvimento de SoftwareMetodologias de Desenvolvimento de Software
Metodologias de Desenvolvimento de Software
 
Java introdução ao java
Java   introdução ao javaJava   introdução ao java
Java introdução ao java
 
JavaScript - Introdução com Orientação a Objetos
JavaScript - Introdução com Orientação a ObjetosJavaScript - Introdução com Orientação a Objetos
JavaScript - Introdução com Orientação a Objetos
 
Aula 01 - JavaScript: Introdução
Aula 01 - JavaScript: IntroduçãoAula 01 - JavaScript: Introdução
Aula 01 - JavaScript: Introdução
 
eXtreme Programming (XP)
eXtreme Programming (XP)eXtreme Programming (XP)
eXtreme Programming (XP)
 
Modelo de Prototipação
Modelo de PrototipaçãoModelo de Prototipação
Modelo de Prototipação
 
Introdução sobre desenvolvimento web
Introdução sobre desenvolvimento webIntrodução sobre desenvolvimento web
Introdução sobre desenvolvimento web
 
BDD (Behavior-Driven Development)
BDD (Behavior-Driven Development)BDD (Behavior-Driven Development)
BDD (Behavior-Driven Development)
 
Aula - Modelos de Processos de Desenvolvimento de Software / Mobile App
Aula - Modelos de Processos de Desenvolvimento de Software / Mobile AppAula - Modelos de Processos de Desenvolvimento de Software / Mobile App
Aula - Modelos de Processos de Desenvolvimento de Software / Mobile App
 
Introdução a Linguagem Java
Introdução a Linguagem JavaIntrodução a Linguagem Java
Introdução a Linguagem Java
 
tmn - Introdução ao JavaScript
tmn - Introdução ao JavaScripttmn - Introdução ao JavaScript
tmn - Introdução ao JavaScript
 
Introdução à Programação Web com Angular
Introdução à Programação Web com AngularIntrodução à Programação Web com Angular
Introdução à Programação Web com Angular
 
Aula01-JavaScript
Aula01-JavaScriptAula01-JavaScript
Aula01-JavaScript
 
Apresentação da UML
Apresentação da UMLApresentação da UML
Apresentação da UML
 
Robot Framework - principais características
Robot Framework - principais característicasRobot Framework - principais características
Robot Framework - principais características
 

Ähnlich wie Arquitetura em camadas em python e quanto isso pode ajudar

Ähnlich wie Arquitetura em camadas em python e quanto isso pode ajudar (20)

Clean Architecture
Clean ArchitectureClean Architecture
Clean Architecture
 
Como DDD e Strategic Design estão nos ajudando a modernizar um Legado
Como DDD e Strategic Design estão nos ajudando a modernizar um LegadoComo DDD e Strategic Design estão nos ajudando a modernizar um Legado
Como DDD e Strategic Design estão nos ajudando a modernizar um Legado
 
Escalando apps com React e Type Script e SOLID
Escalando apps com React e Type Script e SOLIDEscalando apps com React e Type Script e SOLID
Escalando apps com React e Type Script e SOLID
 
PHP Turbinado com CodeIgniter - Conisli 2011
PHP Turbinado com CodeIgniter - Conisli 2011PHP Turbinado com CodeIgniter - Conisli 2011
PHP Turbinado com CodeIgniter - Conisli 2011
 
Não deixe seu projeto só nas mãos do framework
Não deixe seu projeto só nas mãos do frameworkNão deixe seu projeto só nas mãos do framework
Não deixe seu projeto só nas mãos do framework
 
Palestra nosql
Palestra nosqlPalestra nosql
Palestra nosql
 
TDC2016SP - Trilha Microservices
TDC2016SP - Trilha MicroservicesTDC2016SP - Trilha Microservices
TDC2016SP - Trilha Microservices
 
O que vi na QCon 2012 São Paulo
O que vi na QCon 2012 São PauloO que vi na QCon 2012 São Paulo
O que vi na QCon 2012 São Paulo
 
Desenvolvimento de aplicações embarcadas utilizando Python
Desenvolvimento de aplicações embarcadas utilizando PythonDesenvolvimento de aplicações embarcadas utilizando Python
Desenvolvimento de aplicações embarcadas utilizando Python
 
Utilizando NoSQL no desenvolvimento de soluções inteligentes
Utilizando NoSQL no desenvolvimento de soluções inteligentesUtilizando NoSQL no desenvolvimento de soluções inteligentes
Utilizando NoSQL no desenvolvimento de soluções inteligentes
 
Componentes Transformers: Combinando o melhor de cada framework
Componentes Transformers: Combinando o melhor de cada frameworkComponentes Transformers: Combinando o melhor de cada framework
Componentes Transformers: Combinando o melhor de cada framework
 
Infraestrutura como código Terraform aws openshift Ansible
Infraestrutura como código Terraform aws openshift AnsibleInfraestrutura como código Terraform aws openshift Ansible
Infraestrutura como código Terraform aws openshift Ansible
 
Estratégias de Estruturação de Código-fonte e Controlo de Versão
Estratégias de Estruturação de Código-fonte e Controlo de VersãoEstratégias de Estruturação de Código-fonte e Controlo de Versão
Estratégias de Estruturação de Código-fonte e Controlo de Versão
 
O que seus testes garantem, o funcionamento do código ou das funcionalidades ...
O que seus testes garantem, o funcionamento do código ou das funcionalidades ...O que seus testes garantem, o funcionamento do código ou das funcionalidades ...
O que seus testes garantem, o funcionamento do código ou das funcionalidades ...
 
O que move a web atualmente?
O que move a web atualmente?O que move a web atualmente?
O que move a web atualmente?
 
Projeto de API, por Gilmar P.S
Projeto de API, por Gilmar P.SProjeto de API, por Gilmar P.S
Projeto de API, por Gilmar P.S
 
Projeto de API - TDC 2014 - Floripa - Trilha Arquitetura - 18/05/2014
Projeto de API - TDC 2014 - Floripa - Trilha Arquitetura - 18/05/2014Projeto de API - TDC 2014 - Floripa - Trilha Arquitetura - 18/05/2014
Projeto de API - TDC 2014 - Floripa - Trilha Arquitetura - 18/05/2014
 
Boas Práticas em Aplicações na Nuvem: Twelve-Factor App | MVPConf Latam 2021
Boas Práticas em Aplicações na Nuvem: Twelve-Factor App | MVPConf Latam 2021Boas Práticas em Aplicações na Nuvem: Twelve-Factor App | MVPConf Latam 2021
Boas Práticas em Aplicações na Nuvem: Twelve-Factor App | MVPConf Latam 2021
 
Trabalho 4 Semestre e 5 Semestre 2015
Trabalho 4 Semestre e 5 Semestre 2015Trabalho 4 Semestre e 5 Semestre 2015
Trabalho 4 Semestre e 5 Semestre 2015
 
Aspectos do aprendizado do paradigma orientado a objetos por programadores pr...
Aspectos do aprendizado do paradigma orientado a objetos por programadores pr...Aspectos do aprendizado do paradigma orientado a objetos por programadores pr...
Aspectos do aprendizado do paradigma orientado a objetos por programadores pr...
 

Kürzlich hochgeladen

Kürzlich hochgeladen (6)

ATIVIDADE 1 - LOGÍSTICA EMPRESARIAL - 52_2024.docx
ATIVIDADE 1 - LOGÍSTICA EMPRESARIAL - 52_2024.docxATIVIDADE 1 - LOGÍSTICA EMPRESARIAL - 52_2024.docx
ATIVIDADE 1 - LOGÍSTICA EMPRESARIAL - 52_2024.docx
 
ATIVIDADE 1 - ESTRUTURA DE DADOS II - 52_2024.docx
ATIVIDADE 1 - ESTRUTURA DE DADOS II - 52_2024.docxATIVIDADE 1 - ESTRUTURA DE DADOS II - 52_2024.docx
ATIVIDADE 1 - ESTRUTURA DE DADOS II - 52_2024.docx
 
ATIVIDADE 1 - GCOM - GESTÃO DA INFORMAÇÃO - 54_2024.docx
ATIVIDADE 1 - GCOM - GESTÃO DA INFORMAÇÃO - 54_2024.docxATIVIDADE 1 - GCOM - GESTÃO DA INFORMAÇÃO - 54_2024.docx
ATIVIDADE 1 - GCOM - GESTÃO DA INFORMAÇÃO - 54_2024.docx
 
Padrões de Projeto: Proxy e Command com exemplo
Padrões de Projeto: Proxy e Command com exemploPadrões de Projeto: Proxy e Command com exemplo
Padrões de Projeto: Proxy e Command com exemplo
 
Boas práticas de programação com Object Calisthenics
Boas práticas de programação com Object CalisthenicsBoas práticas de programação com Object Calisthenics
Boas práticas de programação com Object Calisthenics
 
ATIVIDADE 1 - CUSTOS DE PRODUÇÃO - 52_2024.docx
ATIVIDADE 1 - CUSTOS DE PRODUÇÃO - 52_2024.docxATIVIDADE 1 - CUSTOS DE PRODUÇÃO - 52_2024.docx
ATIVIDADE 1 - CUSTOS DE PRODUÇÃO - 52_2024.docx
 

Arquitetura em camadas em python e quanto isso pode ajudar

  • 1. Quanto isso pode ajudar? ARQUITETURA EM CAMADAS EM PYTHON
  • 2. ITENS QUE VEREMOS SOBRE ESSE ASSUNTO ⇝ O que é arquitetura em camadas; ⇝ Pensar em camadas ainda é importante? ⇝ Aplicando uso de camadas em Python; ⇝ Padrões de projetos, como eles ajudam a ter camadas; ⇝ Quais vantagens e desvantagens? ⇝ Um caso real do uso de camadas.
  • 4. É UM ESTILO ARQUITETURAL QUE PROPÕE DIVIDIR UM SISTEMA EM VÁRIAS CAMADAS DE ACORDO COM A RESPONSABILIDADE DE CADA PARTE DO SOFTWARE. ESSE ESTILO PROPÕE QUE: ⇝ AS CAMADAS TENHAM UM PROPÓSITO BEM DEFINIDO; ⇝ CADA CAMADA CONHEÇA APENAS CAMADAS ABAIXO DELA; ⇝ AS CAMADAS POSSAM SER REAPROVEITÁVEIS.
  • 5. UM DESENHO TRADICIONAL DE CAMADAS...
  • 6. O USO DE CAMADAS EM SOFTWARE GANHOU FORÇA NA DÉCADA DE 90, COM USO DE 2 CAMADAS. LOGO DEPOIS GANHOU MAIS POPULARIDADE COM O USO DE 3 CAMADAS. O CONCEITO NÃO NASCEU NO MUNDO DE SOFTWARE, OUTRAS ÁREAS O USAM HÁ MUITO TEMPO! E NO MUNDO DE SOFTWARE ELE TAMBÉM É APLICADO HÁ MAIS TEMPO DO QUE PARECE.
  • 8. E… NA MINHA APLICAÇÃO PENSAR EM CAMADAS AINDA É IMPORTANTE? ⇝ MESMO COM ARQUITETURA ORIENTADA A SERVIÇOS? ⇝ MESMO COM MICRO-SERVIÇOS ? ⇝ MESMO COM CLOUD? DEVEMOS AINDA TER QUE PENSAR EM CAMADAS? SIM !!!
  • 9. VOCÊ PODE NÃO SABER OU ATÉ NÃO QUERER, MAS GERALMENTE SUA APLICAÇÃO ESTÁ EM CAMADAS !!! WEB APP MOBILE APP DATABASE CONTROLLERS REST DOMAIN SERVICE REPOSITORY MODEL RELATIONAL NOSQL EXTERNAL SERVICES REST SERVICES MESSAGE QUEUE OTHERS FRONT BACK
  • 10. E COMO POSSO APLICAR CAMADAS EM PYTHON ?
  • 11. VAMOS USAR UM EXEMPLO !. apenas backend . Um projeto simples, chamado: Quotes Box (Caixinha de Citações) que usa os frameworks: Flask e SQLAlchemy
  • 13. O projeto começa pequeno.
  • 14. Mas, o projeto cresce um pouco...
  • 15. E... o projeto cresce mais ainda...
  • 16. o projeto é dividido em camadas!
  • 17. O fonte é dividido em vários arquivos .py...
  • 18. pronto, o projeto está usando arquitetura em camadas !!! só que não ! E PORQUE ?
  • 19. novos recursos são necessários… ⇝ Executar processos agendados (cron); ⇝ Suportar volume alto de requisições; ⇝ Trabalhar com outros bancos de dados; dificuldades na implementação surgem… ⇝ Com mais desenvolvedores há conflitos na codificação; ⇝ Fazer testes está cada vez mais difícil; ⇝ ...
  • 20. eu consigo ____ ? ⇝ Executar rotinas de negócio sem usar API rest... ⇝ Trocar de forma fácil meu framework que expõe rest... ⇝ Optar por salvar os dados em nosql ou relacional... ⇝ Aplicar testes a partes específicas de forma simples... ⇝ Dividir o trabalho entre o time sem gerar conflito... ⇝ Evoluir o sistema sem precisar refatorar tudo... e.. diante disso, nos perguntamos:
  • 21. o que pode ser feito para realmente usar camadas no projeto?
  • 22. Comece separando em pacotes, representando as camadas. Projeto Único quote-box-core==1.0.0 Projeto Core Projeto App Ou
  • 23. Tenha cuidado com dependência entre camadas Camada domain não deveria conhecer coisas da camada acima Usando apenas SQLAlchemy
  • 24. ⇝ A falta de tipagem facilita esperar atributos da camada de cima que não fazem parte do modelo da camada em questão; ⇝ Métodos decorrentes de necessidades da camada de cima, como: to_json(), json(); ⇝ Camadas esperando variáveis de ambiente definidas na camada de cima; ⇝ Tipo de dados específico de um bancos de dados. e... o que mais precisamos ter atençao?
  • 25. ⇝ Camadas que serão usadas como bibliotecas, é melhor usar objetos como estrutura de dados e evitar dicionários; ⇝ Frameworks que “geram tudo” mas não em camadas, ou organizado em camadas mas com dependências implícitas entre uma camada e a camada acima. ⇝ Não confiar apenas nos “olhos”, usar ferramentas que validem a arquitetura. Ex.: Structure101. precisamos ter atençao também em...
  • 26. E… o que podemos estudar para trabalhar corretamente com camadas?
  • 27. princípios de orientação a objetos e PADRÕES DE PROJETO
  • 28. quais deles podem me ajudar? ⇝ Princípios SOLID; ⇝ Padrões GoF; ⇝ Padrões GRASP; ⇝ Padrão MVC;
  • 29. CAMADAS SÓ SE APLICAM A SOLUÇÕES COM BACKEND/FRONTEND? Não !... DOMAINCONTROLLER JSON YAML LINE ARGUMENTS EXTERNAL CLIENTS APP DE DEPLOY EXECUTADA VIA LINHA DE COMANDO.
  • 30. TODA SOLUÇÃO DEVERIA SER ARQUITETADA EM CAMADAS? Não !... Isso não é uma regra, esse estilo não resolve todos seus problemas, mas geralmente ajuda! Entenda bem o negócio e o momento do projeto!
  • 31. QUAIS VANTAGENS? ⇝ Maior organização do código; ⇝ Código mais testável; ⇝ Software modularizado; ⇝ Divisão de responsabilidade; ⇝ Maior adaptabilidade; ⇝ Maior reusabilidade; ⇝ Maior escalabilidade. E DESVANTAGENS? ⇝ Maior número de Classes; ⇝ Maior complexidade na execução do sistema; ⇝ Menos performance dependendo da forma de comunicação entre as camadas; ⇝ Maior complexidade no versionamento; ⇝ Requer maior conhecimento e maturidade do desenvolvedor.
  • 32. COMO O USO DE CAMADAS AJUDA NA CONSTRUÇÃO DE SOLUÇÕES CORPORATIVAS NA NEXXERA.
  • 34. OBRIGADO A TODOS! isaacsouza@gmail.com Projeto exemplo em: https://gitlab.com/betterdeveloper-examples/ quotes-box-layers Slides em: https://pt.slideshare.net/betterdeveloper www.betterdeveloper.net PERGUNTAS? BONS LIVROS QUE AJUDAM NO ASSUNTO... agile software development, principles, patterns and pratices