Baseado nos requisitos apresentados pelo cliente a Py.nk está desenvolvendo um sistema que, fomentado sobre metodologias ágeis, entrega um internet banking com funções básicas de funcionamento e uma interface de administração para gerenciamento da aplicação. Para a realização deste, três principais atores foram levantados: o cliente que pode ser chamado também de usuário comum, deve poder realizar a requisição de cadastro, login, emissão de extrato bancário, movimentações em conta (depósito em caixa, saque e transferência) que geram no momento de execução um comprovante, requisição de atualização de dados e requisição de fechamento de conta; o gerente de agência é a entidade que gerencia uma unidade do banco (agência), deve poder realizar qualquer operação que um usuário comum realiza e além disso deve conseguir aceitar ou recusar requisições de abertura de conta de usuário, aceitar ou recusar requisições de alteração de dados de clientes, realizar a conferência de depósito em caixa e requerir alteração de seus próprios dados ao gerente geral; o gerente geral (além de todas as outras funcionalidades citadas das outras entidades) deve ter acesso ao gerenciamento das agências, dos gerentes de agência e do montante total do banco. Além das funcionalidades dos usuários o banco também deve conter tratativas para problemas como o arredondamento de casas decimais, rendimento de poupança e etc.
A Sprint 1 ocorreu dentro dos conformes, erramos detalhes de execução como comentários pouco descritivos no Git e apresentação. Porém, foi muito importante no sentido de entendermos o passo do time, reconhecermos fragilidades e barreiras pessoais. Os acertos percebidos pelo time foram a cooperação, empenho, entrega e organização. Enquanto que os erros foram mal organização da sprint planning, tempo de estudo irreal e ausência de alguns integrantes do grupo. É bom ressaltar que muitos desses erros foram causados por falta de conhecimento ou pouca experiência do grupo e que esses pontos foram levantados em conjunto com todos os integrantes.
Destaque da Sprint 1: Felipe Augusto Graciano.
📈 Burndown Chart da Sprint 1:
📌 Nota: Como podemos observar no Burndown, nós erramos no planejamento e estouramos as horas que estavam planejadas. Isso se deve a falta de familiaridade com o próprio tempo de desenvolvimento e pela falta de um método lógico para estimativa de tempo durante a sprint planning.
GIF do Produto entregue na Sprint 1:
A Sprint 2 apresentou mudanças muito claras em relação a Sprint 1, muitas delas em decorrência de um momento mais maduro do grupo como um todo em quesitos técnicos, pessoais e etc. Em questões de desenvolvimento foi uma Sprint bem performática, funcionalidades centrais do sistema foram adicionadas e orquestradas com certa facilidade, a grande barreira foi realmente a divergência e a dificuldade em manejar situações pessoais que atrasaram e prejudicaram o grupo como um todo, dessa forma, após as reuniões do final da Sprint é possível que alguns integrantes saiam do grupo. Os acertos percebidos foram organização e produtividade. Enquanto que os erros observados foram integrantes improdutivos, negligência do projeto por condições pessoais e irresponsabilidade.
Destaques da Sprint 2 (empate): Miguel Carvalho Soares e Otávio Abreu dos Santos Silva.
📈 Burndown Chart da Sprint 2:
Vídeo Explicativo da Sprint 2:
https://youtube.com/playlist?list=PLRXTJkGiG2dCUPO1bKY9gwbTKAaoF9Kdp
A Sprint 3 foi uma sprint extremamente produtiva, nela foram realizadas maior parte das tarefas densas com várias regras de negócio de forma a praticamente finalizar o produto. Sobrando assim para a Sprint 4 as atividades que são em sua maioria somente melhorias de qualidade de vida, reformulação de algumas partes que não contemplam mais a situação do projeto e algumas alterações nas regras de negócio que foram questionadas pelo cliente. Apesar da perda de integrantes o grupo apresentou melhorias em diversos aspectos, sendo assim, uma alteração positiva para a equipe. Os acertos percebidos foram produtividade e comprometimento. Enquanto que os erros observados foram falta de comunicação e negligência das cerimônias SCRUM.
Destaque da Sprint 3: Otávio Abreu dos Santos Silva.
📈 Burndown Chart da Sprint 3:
Vídeo Explicativo da Sprint 3:
https://youtube.com/playlist?list=PLRXTJkGiG2dCUPO1bKY9gwbTKAaoF9Kdp
A Sprint 4 foi, em suma, uma etapa de refatoração, tanto das funcionalidades quanto do visual do projeto. Além disso foram implementados os requisitos restantes da aplicação, como o sistema de conta poupança e a responsividade para qualquer dispositivo, visando assim atender à todas as exigências do cliente. Os acertos percebidos foram na organização e adaptabilidade perante as constantes mudanças no pranejamento. Enquanto que os erros observados foram as cerimônias SCRUM pouco enfatizadas e engajamento inferior ao esperado.
Destaque da Sprint 4: Miguel Carvalho Soares e Elaine Aparecida dos Santos.
https://youtube.com/playlist?list=PLRXTJkGiG2dCUPO1bKY9gwbTKAaoF9Kdp
📈 Burndown Chart da Sprint 4:
Vídeo Explicativo da Sprint 4:
https://youtube.com/playlist?list=PLRXTJkGiG2dCUPO1bKY9gwbTKAaoF9Kdp
O projeto está sendo desenvolvido utilizando metodologias ágeis de gerenciamento, no nosso caso o SCRUM. Também achamos pertinente adotar um método de estimativa de tempo de desenvolvimento chamado Estimativa PERT (Program Evaluation and Review Technique) que consiste em uma fórmula que pondera matematicamente um espectro de estimativas que possui três possiveis elementos de tempo: otimista, mais provavel e pessimista. O que a fórmula faz é reajustar a amostra para algo que apesar de considerar extremos, avalia eles como avaria dando um peso maior pro tempo que comumente vai acontecer mais (mais provável). A fórmula foi implementada na Sprint 2 e tem se mostrado muito assertiva. Outro ponto interessante para ser abordado é que apesar de o nome ser API o programa não é uma Application Programming Interface, isso pois o nome se dá a metodologia de aprendizado implantada na Fatec SJC que inclusive atingiu reconhecimento internacional pelo MIT (Massachusetts Institute of Technology) com um selo chamado CDIO (Conceive Design Implement Operate). Aprendizagem por Projetos Integrados é o nome da metodologia de ensino que por padrão esta contemplada no nome do projeto.
📌 Nota: A coluna ID Requisição do Backlog está associada a um arquivo de circulação interna acordado com o cliente. Este não está contemplado por motivos de privacidade do mesmo, entretanto, a coluna foi mantida para fins avaliativos.
ID | US | Sprint |
---|---|---|
US01 | Eu, enquanto usuário comum, desejo realizar depósitos em espécie, para conseguir realizar operações com meu dinheiro dentro do banco. | 1 |
US02 | Eu, enquanto usuário comum, desejo realizar saques em caixa, para retirar o dinheiro guardado no banco. | 1 |
US03 | Eu, enquanto usuário comum, desejo realizar requisição de abertura de conta, para abrir uma conta dentro do banco. | 1 |
US04 | Eu, enquanto usuário comum, desejo realizar a requisição de alteração de dados, para atualizar meus dados cadastrais. | 2 |
US05 | Eu, enquanto usuário comum, desejo realizar a requisição de cancelamento de conta, para cancelar uma conta dentro do banco. | 2 |
US06 | Eu, enquanto usuário comum, desejo realizar movimentações de dinheiro da minha conta para outra conta do mesmo banco utilizando uma "chave", para realizar transferências de dinheiro. | 2 |
US07 | Eu, enquanto usuário comum, desejo que seja realziado emissão de comprovantes imediatamente após qualquer operação, para conseguir comprovar minhas movimentações feitas em minha conta bancária | 2 |
US08 | Eu, enquanto Gerente de Agência, desejo ter todas as funcionalidades de um usuário comum, para poder ter um conta dentro do banco como um cliente. | 2 |
US09 | Eu, enquanto Gerente de Agência, desejo ver todas operações de depósito em caixa de minha agência, para após a conferência "física" aceitar ou recusar a operação. | 2 |
US10 | Eu, enquanto Gerente de Agência, desejo ver todas as requisições de abertura de conta de minha agência, para poder recusar ou aceitar a abertura de conta. | 2 |
US11 | Eu, enquanto Gerente de Agência, desejo ver as requisições de alteração de dados cadastrais de usuários de minha agência, para aceitar ou recusar a operação. | 2 |
US12 | Eu, enquanto Gerente de Agência, desejo ver todas as requisições de cancelamento de conta bancárias, para poder cancelar uma conta que não esteja devendo ou tenha nenhum dinheiro guardado. | 2 |
US13 | Eu, enquanto Gerente Geral, desejo ter todas as funcionalidades de um usuário comum e um Gerente de Agência, para que não haja restrições internas de sistema. | 3 |
US14 | Eu enquanto gerente Geral, desejo gerenciar usuário do tipo gerente de agência, para poder alterar, criar, deletar, ver todos os Gerentes de Agências e ver atrelar um gerente a uma Agência. | 3 |
US15 | Eu, enquanto Gerente Geral, desejo gerenciar Agências, para poder alterar, criar, deletar e ver todas as Agências. | 3 |
US16 | Eu, enquanto Gerente Geral, desejo alterar o capital total do banco, para atualizar o capital do banco e corrigir inconsistências. | 3 |
US17 | Eu, enquanto usuário comum (cliente), desejo ter uma interface acessível e intuitiva, para ter uma boa experiência durante a utilização do sistema. | 3 |
US18 | Eu, enquanto Gerente Geral, desejo que toda movimentação de dinheiro altera o valor total de acordo com o tipo de transação, para que o capital total do banco tenha consistência com a realidade | 4 |
US19 | Eu, enquanto Usuário comum, desejo que quando meu saldo fique negativo minha conta em status de cheque especial, para que eu posso realizar empréstimos do banco | 4 |
Sprint | ID US | ID Função | ID Requisição | Funções | Prioridade | Status |
---|---|---|---|---|---|---|
1 | US01 | F.1 | RF.3 | Depósito em espécie | ALTA | Feito |
1 | US02 | F.2 | RF.3 | Saque em espécie | ALTA | Feito |
1 | US10 | F.3 | RF.3 | Criação de conta de usuário comum | ALTA | Feito |
2 | US07 | F.4 | RF.3 | Geração de extratos | MÉDIA | Feito |
2 | US07 | F.4 | RF.3 | Emissão de Comprovante | MÉDIA | Feito |
2 | US09 | F.5 | RF.2 | Conferência de depósito | MÉDIA | Feito |
2 | US04 | F.6 | RF.3 | Requisição de alteração de dados | MÉDIA | Feito |
2 | US05 | F.7 | RF.3 | Requisição de cancelamento de conta | MÉDIA | Feito |
2 | US03 | F.8 | RF.3 | Requisição de criação de conta | MÉDIA | Feito |
2 | US06 | F.9 | RF.3 | Transferência em contas do mesmo banco | MÉDIA | Feito |
2 | US18 | F.10 | RF.6 | Não aceitar qualquer saque que extrapole o valor total do banco. | MÉDIA | Feito |
2 | US10 | F.11 | RF.2 | Aceite ou recusa de requisição de abertura de conta | MÉDIA | Feito |
2 | US11 | F.12 | RF.2 | Aceite ou recusa de requisição alteração de dados de usuário | MÉDIA | Feito |
3 | US12 | F.13 | RF.2 | Aceite ou recusa de requisição de fechamento de conta de usuário | MÉDIA | Feito |
3 | US15 | F.14 | RF.1 | Criar Agência | MÉDIA | Feito |
3 | US14 | F.15 | RF.1 | Criar Gerente de Agência | MÉDIA | Feito |
3 | US14 | F.16 | RF.1 | Alterar dados de Gerente de Agência | BAIXA | Feito |
3 | US14 | F.17 | RF.1 | Deletar Gerente de Agência | BAIXA | Feito |
3 | US14 | F.18 | RF.1 | Atrelar Gerente de Agência a uma Agência | BAIXA | Feito |
3 | US16 | F.19 | RF.1 | Gerenciar o capital total do banco | BAIXA | Feito |
3 | US15 | F.20 | RF.1 | Fechamento de agência | BAIXA | Feito |
3 | US15 | F.21 | RF.1 | Alterar dados de Agência | BAIXA | Feito |
3 | US18 | F.22 | RF.4, RF.5 | Alteração do capital total do banco de acordo com os saques e Depósitos | BAIXA | Feito |
3 | US19 | F.23 | RF.12, RF.13 | Função de cheque especial | BAIXA | Feito |
3 | US20 | F.24 | RF.7 | Truncamento dos valores com as correções apropriadas para evitar inconsistência de dados. | BAIXA | Feito |
4 | F.23 | RF.9 | Remuneração da poupança | BAIXA | Feito | |
4 | F.24 | RF.10 | Remuneração da poupança configurável | BAIXA | Feito |
•Instalação
-
Baixe o Python
No site oficial do Python na aba de downloads procure pelo seu sistema operacional e siga os passos de instalação. https://www.python.org/downloads/
-
Adicionando ao Path (sistemas Windows somente)
Durante a instalação do Python no Windows se a opção de adicionar o Python no Path não for assinalada o sistema operacional não vai conseguir reconhecer o comando 'python' na linha de comando como uma variável de ambiente que remete as funções do Python, essa funcionalidade é necessária para a utilização da nossa aplicação. Portanto DURANTE A INSTALAÇÃO DO PYTHON NO WINDOWS ASSINALE A OPÇÃO "ADD PYTHON <VERSÃO> TO PATH"
•UTILIZANDO A APLICAÇÃO
- Crie um diretório
- Crie um diretório e navegue até ele atraves da linha de comando.
mkdir <nome do diretório>
cd <nome do diretório>
- Clone o repositório
git clone https://github.com/pynkAPI/API-1-DSM_22.git .
- Repare que no final tem um ponto, ele é colocado propositalmente para que não seja criado mais um diretório dentro desse recém criado por você.
- Crie um ambiente virutal
python -m venv <nome do ambiente>
- Utilizamos a variável de ambiente 'python' citada na sessão de instalação, caso esse comando falhe no seu ambiente tente:
python3 -m venv <nome do ambiente>
- Caso mesmo assim o diretório com o nome do ambiente não seja criado assegure-se que o python está configurado em suas variáveis de ambiente e tente novamente o processo.
- Executar o ambiente virtual
- No CMD do Windows:
cd <nome do ambiente>\Scripts
activate.bat
- No PowerShell do Windows:
.\<nome do ambiente>\Scripts\Activate.ps1
- No Unix(Linux)/MacOS:
source <nome do ambiente>/bin/activate
- Instale as dependências:
- Navegue até a raiz do diretório e execute o comando:
pip install -r requirements.txt
-
Configure o Banco de dados
6.1. Abra o seu SGBD e importe o Script SQL
- Dentro do seu sistema de gerenciamento de banco de dados procure pela opção de importar Script SQL.
- Após importado execute todas as linhas.
6.2. Credenciais do Banco
- Dentro da pasta src existe um arquivo chamado "config.conf", altere as credenciais do banco respeitando os espaçamentos de acordo com o seu ambiente, para isso utilize o editor de texto de sua preferência.
-
Executando a aplicação
- Navegue até a pasta src dentro dessa pasta raíz através da linha de comando e execute o arquivo 'app.py'.
cd src
python app.py
- Entrando na aplicação
-
Abra o navegador e digite a url que aparecerá no terminal após a execução do 'app.py'.
-
O caminho /loginG da acesso a tela login de funcionarios, os acessos padrão que vem inseridos para login são:
- Gerente Geral
- Login: GG
- Senha: senha
- Gerente de Agencia 1
- Login: GA1
- Senha: senha
- Gerente de Agencia 2
- Login: GA2
- Senha: senha
- Usuario 1
- Login: 1234
- Senha: teste
- Usuario 2
- Login: 4321
- Senha: teste
- Gerente Geral
-
Para manipular as datas e fazer testes com a poupança e o cheque especial realize o procedimento a seguir:
-
No sgdb utilizado para subir o banco copie o seguinte código e execute:
SELECT TC.id_conta, TC.numeroconta, tch.id_cheque_especial FROM tb_contabancaria TC Inner join tb_cheque_especial tch On tch.id_conta = TC.id_conta WHERE ativo = 1
- Este código retorna quais são as contas que estão em situação de cheque, escolha a que faz sentido pro teste.
-
E então para adicionar um espaço de tempo:
UPDATE tb_cheque_especial SET data_atualizacao = <data> WHERE id_cheque = <id do cheque mostrado no ultimo select>
- A data colocada no código tem de ser MENOR do que a data em que foi feita a requisição, portanto, para simular um mês de cheque pra uma movimentação feita no dia 28/11/22 preencha data com o valor 28/10/22. (LEMBRANDO QUE O FORMATO DA DATA É aaaa-mm-dd)
-
-
IMPORTANTE: Não feche a janela do terminal enquanto estiver utilizando a aplicação.
-