Solved

JasperFillManager fails to create output

Posted on 2015-02-24
6
23 Views
Last Modified: 2016-07-19
I'm trying to upgrade from Jasper Reports 5.5.1 to 6.0 but I can't get any output.  I'm running a standalone java application using compiled jrxml files.

I'm pretty sure it's a library I'm missing but I've gone through the documentation and I have all of the required libraries, so I'm not sure how to troubleshoot this further.

Also the program (at least in netbeans) runs through code in an unexpected fashion that I also can't figure out.

First here are the libraries that are included in the project.
List of librariesHere is the sample code where it fails.
    public static JasperPrint fillReport(String filename, JRParDataSource jrds,
            HashMap<String, Object> parameters) throws JRException {

     JasperPrint jasperPrint = null;
     jasperPrint = JasperFillManager.fillReport(filename, parameters,
                        jrds);
       return jasperPrint;
    }

Open in new window

The program runs the fillReport line but never hits the return jasperPrint line.

Here is the calling routine

    public static void saveJasperPrint(String jasperPath, String jasperFilename,
            String filename, HashMap<String, Object> parameters, JRParDataSource jrds)
            throws JRException {
        jasperPath = FileEx.makePathname(jasperPath, jasperFilename, true);
        jasperPath += ".jasper";

        // create jasperPrint
        JasperPrint jasperPrint = null;
        jasperPrint = fillReport(jasperPath, jrds, parameters);
        // save report
        saveReport(jasperPrint, new File(filename));
    }

Open in new window


After calling fillReport it never returns to run saveReport

And finally the top level caller.
try {   //other code in here
    setProgress(0);
    for (nDone=0; nDone< nTotal; nDone++) {  
             try {
                    // Add current user id to filename to prevent getting
                    // mixed up with someone else's report.
                        ReportFileIO.saveJasperPrint(criteria.getReportType().filename,
                            criteria.getFilename() + "." + user, parameters, jrds);
                } catch (JRException e) {
                    errors.add(BusinessConstants.dataCentreName + ": Unable to create jasperPrint for " +
                            criteria.getFilename());
                    break;
                }
            }
       }
        catch (Exception e) {
            errors.add(e.getMessage() + "\n" + Trace.printTrace(e));
        } finally {
            setProgress(100);
            return errors.isEmpty() ? null : errors;
        }

Open in new window


The call to saveJasperPrint happens and the return goes directly to the finally statement without being caught in any of the exception handlers.  

So I'm not sure how to resolve this problem.
0
Comment
Question by:geekdad1
  • 4
  • 2
6 Comments
 
LVL 16

Expert Comment

by:krakatoa
ID: 40628971
The program runs the fillReport line but never hits the return jasperPrint line.

How do you know that?
0
 
LVL 1

Author Comment

by:geekdad1
ID: 40629249
Running in debug mode under netbeans 7.0  I reach the breakpoint at  fillReport but single stepping from that statement goes right to the finally statement in the top level calling program.
0
 
LVL 16

Expert Comment

by:krakatoa
ID: 40629368
Well from what I see of the API for this, the JasperFillManager.fillReport() methods with 3 args seem to take the Map params as the last argument - maybe you want to check this, iianm. But I could be wrong as I don't do Jasper.
0
Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

 
LVL 1

Author Comment

by:geekdad1
ID: 40629518
This is a working application (at least it was until I tried to upgrade jasper), so I'm quite sure the arguments to the function are fine.
0
 
LVL 1

Accepted Solution

by:
geekdad1 earned 0 total points
ID: 41711411
Closing this as it's too old.
0
 
LVL 1

Author Closing Comment

by:geekdad1
ID: 41718751
Moved on to other problems.  No longer an issue
0

Featured Post

Announcing the Most Valuable Experts of 2016

MVEs are more concerned with the satisfaction of those they help than with the considerable points they can earn. They are the types of people you feel privileged to call colleagues. Join us in honoring this amazing group of Experts.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

INTRODUCTION Working with files is a moderately common task in Java.  For most projects hard coding the file names, using parameters in configuration files, or using command-line arguments is sufficient.   However, when your application has vi…
Introduction This article is the last of three articles that explain why and how the Experts Exchange QA Team does test automation for our web site. This article covers our test design approach and then goes through a simple test case example, how …
Viewers learn about the “while” loop and how to utilize it correctly in Java. Additionally, viewers begin exploring how to include conditional statements within a while loop and avoid an endless loop. Define While Loop: Basic Example: Explanatio…
This theoretical tutorial explains exceptions, reasons for exceptions, different categories of exception and exception hierarchy.

828 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question