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

Large request problem #6359

Open
wants to merge 2 commits into
base: master
Choose a base branch
from

Conversation

FSchumacher
Copy link
Contributor

Description

Should fix large responses/requests in ViewResultRreader when no linebreaks can be found

Motivation and Context

As described in #6336 JMeter seems to crash, when large request bodies are used in HTTP sampler. This is caused by the used TextArea, which tries to find a good place for breaking and uses too much CPU for this.

One fix, we tried earlier, was to add linebreaks, when large responses are shown. We forgot about requests.
This fix is basically two fixes.

  1. There seems to be a bug in our StringWrap class, that does the insertion of linebreaks.
  2. Move the use of StringWrap into the problematic JSyntaxTextArea, so that all data that is shown by the problematic component is automatically wrapped with linebreaks.

If this fix seems to help, we could remove the usage of StringWrap in the old places.

How Has This Been Tested?

Used a simple test plan, that generates a HTTP body with ${__groovy("abc" * 1_000_000)}. Without this patch, JMeter seems to be crashed. With the fix, it will be responsive (after a short while).

Screenshots (if appropriate):

Types of changes

  • Bug fix (non-breaking change which fixes an issue)
  • Breaking change (fix or feature that would cause existing functionality to not work as expected)
    This will insert linebreaks in large data chunks that are displayed with JSyntaxTextArea

Checklist:

  • My code follows the code style of this project.
  • I have updated the documentation accordingly.

@bhecquet
Copy link

You saved my day
I've compiled and tested your JMeter version with my project, sending a 400kb JSON
With default configuration, there is still a freeze of about 1 minute
But, when a set

view.results.tree.max_line_size=1000
view.results.tree.soft_wrap_line_size=1000
view.results.tree.max_size=1048576
view.results.tree.simple_view_limit=1000

Then, everything is OK, no more waits

From the above settings, I cannot tell which one helps

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.

2 participants