Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ci: Set up AppMap #21

Closed
wants to merge 7 commits into from
Closed

ci: Set up AppMap #21

wants to merge 7 commits into from

Conversation

dustinbyrne
Copy link

This pull request was created by the AppMap CI setup assistant.

To continue, return to https://getappmap.com/setup/github_auto/progress.

Steps to merge:

  • Review the automated commit which adds the AppMap language agent and appmap.yml.
  • Review the "AppMap configuration report" generated by the workflow run.

Copy link

github-actions bot commented Nov 7, 2023

AppMap runtime code review

Summary Status
Failed tests ✅ All tests passed
API changes 0️⃣ No API changes
Security flaws ✅ None detected
Performance problems ✅ None detected
Code anti-patterns ✅ None detected
New AppMaps 0️⃣ No new AppMaps

Copy link

github-actions bot commented Nov 7, 2023

AppMap configuration report

Success! Your project has been successfully configured to record AppMaps when
you run your tests.

Continue with AppMap Setup >>


The following sections contain detailed information about the AppMap integration with your project.

AppMap data sources

In GitHub Actions and other CI systems, AppMaps are created by recording
test cases. Here's how the AppMaps in this project were created:

pie showData
  title Sources of AppMap data in this project
  "junit" : 47
  "request_recording" : 5
Loading

Code recording settings

Your appmap.yml configuration file specifies all the code that you want AppMap to instrument and record.
By default, sub-modules of any requested code are recorded as well. In this project, the packages specified
in appmap.yml are:

- path: org.springframework.samples.petclinic

By applying this configuration to your java project, AppMap has recorded the
following packages and modules:

Web service API profile

When you record AppMaps that include HTTP server requests, AppMap automatically generates OpenAPI definitions
based on the observed data.

63% of the AppMaps in this project contain at least one HTTP server request.

8% of the AppMaps in this project contain more than one HTTP server request.

Here's a summary of the web service routes that are provided by this project:

/error /owners /owners/find /owners/new /owners/{ownerId} /vets /vets.html

And here are the different content types served by the API:

Response Content Type Number of Routes
application/json 2
text/html 15

As you change your code and tests, AppMap will automatically update the OpenAPI definitions.
You'll see a summary of the REST API changes in each pull request.

SQL profile

When your code makes a SQL query, AppMap records the SQL query in detail. It even parses the queries
to figure out which tables your app is using, and how it's using them.

37% of the AppMaps in this project contain at least one SQL query.

35% of the AppMaps in this project contain more than one SQL query.

Here are the SQL tables that are present in the observed queries:

owners pets specialties types vet_specialties vets visits

Large AppMaps

Some tests can produce large AppMaps, because they exercise longer or highly repeated code paths.
AppMap runtime code review is optimized for AppMaps that
are less than 10 MB in size. You may want to consider disabling AppMap for tests that produce
large AppMaps, since they can slow down your CI job and they are hard to analyze. Also, note that
AppMaps greater than 50 MB in size will not be analyzed at all.

You can disable recording of a test case by adding a code comment or annotation to the test case file.
Learn how by visiting the
reference documentation for appmap-java.

This project doesn't have any AppMaps that are greater than 1 MB in size.

Frequently recorded functions

The AppMap configuration file appmap.yml specifies which functions to record.
Some functions may be called very frequently, adding little to the understandability of the code
while adding a lot of overhead to the AppMap recording process.

Note that some functions are automatically added to the recording by
the AppMap agent. For example, the AppMap agent automatically records functions that are
relevant to detecting security flaws and performance problems. If you disable recording of these
functions, then some problems may become undetectable.

You can disable recording of a class or function by updating the appmap.yml configuration file.
Learn how by visiting the
reference documentation for appmap-java.

This project doesn't have any recorded functions that occur more than 1000 times.

Learn more

To learn more about AppMap, visit
appmap.io/docs.

@dustinbyrne dustinbyrne closed this Nov 7, 2023
@dustinbyrne dustinbyrne deleted the appmap-ci branch November 7, 2023 15:48
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant