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

How to see detailed error description for warc validate? #170

Open
tuehlarsen opened this issue Nov 12, 2024 · 1 comment
Open

How to see detailed error description for warc validate? #170

tuehlarsen opened this issue Nov 12, 2024 · 1 comment

Comments

@tuehlarsen
Copy link

tuehlarsen commented Nov 12, 2024

When a warc.gz file fails with an error - i can't see the detailed errors message:
e.g.
/home/prod/warc validate ./470779-431-20241101123640123-00000-kb-prod-har-013.kb.dk.warc.gz
Total time: 22.941703205s, files: 1, records: 25546, processed: 25546, errors: 1, duplicates: 0

Is that not possible?

When I use jwat i get following:

Summary of '/home/release_software_dist/PROD/har-013/470779-431-20241101123640123-00000-kb-prod-har-013.kb.dk.warc.gz'

GZip.isValid: false
GZip.Entries: 25545
 GZip.Errors: 0

GZip.Warnings: 0
Warc.isValid: true
Warc.Records: 25546
Warc.Errors: 0
Warc.Warnings: 0

Job summary

GZip files: 0

  • Arc: 0
  • Warc: 1
    Arc files: 0
    Warc files: 0
    Errors: 0
    Warnings: 0
    RuntimeErr: 1
    Skipped: 0
    Time: 00:00:37 (37507 ms.)
    TotalBytes: 91.8 mb
    AvgBytes: 2.4 mb/s

Exception while processing '/home/release_software_dist/PROD/har-013/470779-431-20241101123640123-00000-kb-prod-har-013.kb.dk.warc.gz'

StartOffset: 96236201 (0x5bc72a9)
Offset: 96280576 (0x5bd2000)
java.io.IOException: java.util.zip.DataFormatException: Data missing!
at org.jwat.gzip.GzipReader$GzipEntryInputStream.read(GzipReader.java:645)
at java.io.BufferedInputStream.fill(BufferedInputStream.java:246)
at java.io.BufferedInputStream.read1(BufferedInputStream.java:286)
at java.io.BufferedInputStream.read(BufferedInputStream.java:345)
at java.io.FilterInputStream.read(FilterInputStream.java:133)
at java.io.PushbackInputStream.read(PushbackInputStream.java:186)
at org.jwat.common.ByteCountingPushBackInputStream.read(ByteCountingPushBackInputStream.java:124)
at java.io.FilterInputStream.read(FilterInputStream.java:133)
at java.io.PushbackInputStream.read(PushbackInputStream.java:186)
at org.jwat.common.ByteCountingPushBackInputStream.read(ByteCountingPushBackInputStream.java:124)
at org.jwat.common.FixedLengthInputStream.read(FixedLengthInputStream.java:103)
at java.io.BufferedInputStream.fill(BufferedInputStream.java:246)
at java.io.BufferedInputStream.read1(BufferedInputStream.java:286)
at java.io.BufferedInputStream.read(BufferedInputStream.java:345)
at java.io.FilterInputStream.read(FilterInputStream.java:133)
at java.io.PushbackInputStream.read(PushbackInputStream.java:186)
at org.jwat.common.ByteCountingPushBackInputStream.read(ByteCountingPushBackInputStream.java:124)
at java.security.DigestInputStream.read(DigestInputStream.java:161)
at java.io.FilterInputStream.read(FilterInputStream.java:133)
at java.io.FilterInputStream.read(FilterInputStream.java:133)
at java.io.PushbackInputStream.read(PushbackInputStream.java:186)
at org.jwat.common.ByteCountingPushBackInputStream.read(ByteCountingPushBackInputStream.java:124)
at org.jwat.common.ByteCountingPushBackInputStream.read(ByteCountingPushBackInputStream.java:119)
at org.jwat.archive.ManagedPayload.manageRecord(ManagedPayload.java:254)
at org.jwat.archive.ManagedPayload.manageWarcRecord(ManagedPayload.java:219)
at org.jwat.tools.tasks.test.TestFile2.apcWarcRecordStart(TestFile2.java:199)
at org.jwat.archive.ArchiveParser.parse(ArchiveParser.java:154)
at org.jwat.tools.tasks.test.TestFile2.processFile(TestFile2.java:58)
at org.jwat.tools.tasks.test.TestTask$TaskRunnable.run(TestTask.java:266)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
at java.lang.Thread.run(Thread.java:750)
Caused by: java.util.zip.DataFormatException: Data missing!
at org.jwat.gzip.GzipReader.readInflated(GzipReader.java:566)
at org.jwat.gzip.GzipReader$GzipEntryInputStream.read(GzipReader.java:641)
... 33 more

-->

@maeb
Copy link
Member

maeb commented Jan 15, 2025

Hello @tuehlarsen!

The example you provided:

/home/prod/warc validate ./470779-431-20241101123640123-00000-kb-prod-har-013.kb.dk.warc.gz
Total time: 22.941703205s, files: 1, records: 25546, processed: 25546, errors: 1, duplicates: 0

looks like the output from v2.0.1.

In the current latest version v3.0.0-beta.4 the output looks like the following:

$ warc -v
3.0.0-beta.4

$ warc validate testdata/warc/samsung-with-error/rec-33318048d933-20240317162652059-0.warc.gz
time=2025-01-15T11:02:54.635+01:00 level=WARN msg=Invalid file=testdata/warc/samsung-with-error/rec-33318048d933-20240317162652059-0.warc.gz errors=1 records=54
time=2025-01-15T11:02:54.635+01:00 level=ERROR msg="offset: 505719: unexpected EOF" file=testdata/warc/samsung-with-error/rec-33318048d933-20240317162652059-0.warc.gz errors=1 records=54

where the output includes the error detail but the summary info for all files has been removed.

v3 is a refactor of v2 where the output logic has been simplified. The summary information will come back at some point. In addition we would like the exit code of the program to reflect the validation status such that warcaeology would be more suitable to be used in scripts.

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

No branches or pull requests

2 participants