Skip to content

Latest commit

 

History

History
120 lines (81 loc) · 7.49 KB

README.md

File metadata and controls

120 lines (81 loc) · 7.49 KB

Doggos application

The application purpose is to count the number of adopted dogs in the particular dog shelter within a working day.

Description

The application takes the number of the dog adoptions provided to it and generate the report, which can be used later to review the dog shelter activities within the last 24 hours. The report says how many dogs were adopted in the dog shelter per the dog breed.

The application is a simple batch program. It reads the sequential dataset (input) and produces the output sequential dataset (report) as a result. The application written in the plain COBOL language.

Getting started

Dependencies

Note You can run it in any OS (Mac, Windows or Linux).

  1. You have to have Npm and NodeJs installed.
    • You can use node -v to verify the NodeJs installation in the system.
    • You can use npm -v to verify the Npm installation in the system.
  2. You have to have Java installed locally.
    • You can follow this guide to install Java on your machine in case of Mac.
    • You can follow this guide to install Java on your machine in case of Windows.
  3. You have to have Zowe CLI v1 installed locally with a list of required CLI plugins:
    • Zowe CLI: npm install -g @zowe/cli@6.40.2.
    • You have to disable to Secure Credential Store in the Zowe CLI: zowe config reset CredentialManager(just for the simplicity of the use case).
    • Zowe Endevor CLI Plugin: zowe plugins install @broadcom/endevor-for-zowe-cli@6.5.0.
    • Zowe Bridge for Git CLI Plugin: zowe plugins install @broadcom/endevor-bridge-for-git-for-zowe-cli@2.4.1. Note: we need Zowe CLI with the plugins to be able to communicate with the mainframe and build the source code.
  4. You have to have a VSCode IDE installed locally or it's alternative in the browser. Note: you can have some other IDE instead, but the Broadcom can offer you the full development experience in the VSCode only for now.
  5. You have to have a Code4z extensions pack installed in the VSCode. Note: you can also install it in the VSCode interface using this guide. VSCode-extensions Code4z

Installing

  • Please, use this repository and the main branch for the latest source code.

Note: Make sure, that you have a Git installed.

  • Once you have the repository cloned to your system, please, execute the VSCode task DOGGOS: install in it. It is required to get the local project dependencies to be fetched. It may take 1-2 minutes to complete, so please, be patient :)
  • Run the VSCode task: DOGGOS: configure to configure the test environment.

Note: The project installation requires XCode to be installed on the MacOs as an additional prerequisite.

How to execute VSCode tasks

  • Issue the CTRL+SHIFT+P/CMD+SHIFT+P to open a VSCode Command Palette.
  • Choose the Tasks: Run task option from the list.
  • Use the tasks starting with the DOGGOS prefix.

Repository structure

Building (generating or compiling) the program

Please, use the Endevor Bridge for Git Zowe CLI plugin for this purpose. It will get your source code from the GSECONF/DOGGOS folder and build it in the isolated environment on the mainframe. Everything will be cleaned up automatically afterwards, the other developers won't be affected.

Note: There is already a backend setup for the build on the mainframe side.

  • You need to use the VSCode task: DOGGOS: create endevor service profile first, to create an Endevor service profile. Note: this profile helps us to connect to the Endevor backend environment. You only need to run this task once, the profile will be saved in the file system.
  • You can use the VSCode task: DOGGOS: build the source code to build the source code.
  • Review the task output and the listings in the output directory.

Note: the building process may end up with no generation. It means that there were no changes in the source code, in that case, try to add some comment into it and rebuild it, just to trigger the build.

Run the program manually

Please, use Zowe Explorer VSCode extension for this purpose.

Note: There is already a backend setup for the run on the mainframe side.

  • Build the program source code successfully using the guide above.
  • Open Zowe VSCode extension interface: reveal the left column of the VSCode interface and find the big and bold letter Z in there.
  • Zowe-Explorer
  • Search for the datasets in the lpar1.zosmf Data Sets profile folder.
    • Navigate to the lpar1.zosmf node and click into it.
    • Zowe-Explorer-Search
    • Please, use <USERID>.DOGGOS.* pattern to search for the datasets.
  • Expand the <USERID>.DOGGOS.JCL dataset and Right click on the RUNDOGS item.
    • Select Submit JCL option.
    • Zowe-Explorer-Submit
    • Click into the JobID item in the left bottom corner in the pop notification to see the job results.
      • You can click on the job item several times, until the job will be completed.
      • Zowe-Explorer-Job-Submitted

Note: If you want to run the updated source code, please, rebuild the program using the guide above and submit the JCL again.

Run automated tests for the program

Please, use Jest VSCode extension for this purpose.

Note: There is already a backend setup for the tests on the mainframe side.

  • Build the program source code successfully using the guide above.
  • Open the test file in the VSCode editor and review the test cases if needed.
  • Run the tests using the VSCode task: DOGGOS: run tests.

Update the test input

Note: There is already a backend setup for the tests on the mainframe side.

Debugging the program

Please, use Debugger for Mainframe VSCode extension for this purpose.

Note: There is already a backend setup for the debug on the mainframe side.

  • Build the program source code successfully using the guide above.
  • Run the VSCode task: DOGGOS: Update Debugger UserID.
  • Press F5 to start the debugger session.
  • Enter the mainframe password for your username in the popup window.
  • Wait a bit for the debugger to be executed and follow the program flow using this guide.