Files
golib/archive/archive_gzip_test.go
nabbar 99075ec0d4 Package Logger:
- hookfile: simplify recovering of resources
- hookfile: add message to resource when recovering process executed

Package Archive:
- Add test & documentation in each subpackages
- Add GoDoc & exmaples in packages and subpackages
- Update README & TESTING md files

Bump dependencies
2025-12-26 02:40:45 +01:00

119 lines
3.1 KiB
Go

/*
* MIT License
*
* Copyright (c) 2025 Nicolas JUHEL
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*
*/
package archive_test
import (
"bufio"
"io"
"os"
libarc "github.com/nabbar/golib/archive"
arccmp "github.com/nabbar/golib/archive/compress"
. "github.com/onsi/ginkgo/v2"
. "github.com/onsi/gomega"
)
var _ = Describe("TC-GZ-001: archive/compress/gzip", func() {
Context("TC-GZ-010: Write/Read a gzip compressed file", func() {
It("TC-GZ-011: Create a gzip compressed file must succeed", func() {
var (
hdf *os.File
buf *bufio.Writer
wrt io.WriteCloser
)
defer func() {
if hdf != nil {
_ = hdf.Close()
}
}()
arc[arccmp.Gzip.String()] = "lorem_ipsum" + arccmp.Gzip.Extension()
hdf, err = os.Create(arc[arccmp.Gzip.String()])
Expect(err).ToNot(HaveOccurred())
Expect(hdf).ToNot(BeNil())
wrt, err = arccmp.Gzip.Writer(hdf)
Expect(err).ToNot(HaveOccurred())
Expect(wrt).ToNot(BeNil())
buf = bufio.NewWriter(wrt)
_, err = buf.WriteString(loremIpsum)
Expect(err).ToNot(HaveOccurred())
err = buf.Flush()
Expect(err).ToNot(HaveOccurred())
err = hdf.Sync()
Expect(err).ToNot(HaveOccurred())
err = wrt.Close()
Expect(err).ToNot(HaveOccurred())
err = hdf.Close()
Expect(err).ToNot(HaveOccurred())
})
It("TC-GZ-012: Detect and Extract a gzip compressed file must succeed", func() {
var (
hdf *os.File
alg arccmp.Algorithm
rdr io.ReadCloser
buf *bufio.Reader
)
defer func() {
if hdf != nil {
_ = hdf.Close()
}
}()
hdf, err = os.Open(arc[arccmp.Gzip.String()])
Expect(err).ToNot(HaveOccurred())
Expect(hdf).ToNot(BeNil())
alg, rdr, err = libarc.DetectCompression(hdf)
Expect(err).ToNot(HaveOccurred())
Expect(rdr).ToNot(BeNil())
Expect(alg).To(Equal(arccmp.Gzip))
buf = bufio.NewReader(rdr)
_, err = io.Copy(io.Discard, buf)
Expect(err).ToNot(HaveOccurred())
err = buf.UnreadByte()
Expect(err).To(HaveOccurred())
err = rdr.Close()
Expect(err).ToNot(HaveOccurred())
err = hdf.Close()
Expect(err).ToNot(HaveOccurred())
})
})
})