mirror of
https://github.com/hasura/graphql-engine.git
synced 2025-01-07 08:13:18 +03:00
3b0ad30757
PR-URL: https://github.com/hasura/graphql-engine-mono/pull/7216 GitOrigin-RevId: 20a94267eca42edf8e79470711766a3fecac0f50
74 lines
3.0 KiB
Haskell
74 lines
3.0 KiB
Haskell
module Hasura.Server.CompressionSpec (spec) where
|
|
|
|
import Codec.Compression.GZip qualified as GZ
|
|
import Data.ByteString.Lazy qualified as BL
|
|
import Data.Set qualified as Set
|
|
import Hasura.Prelude
|
|
import Hasura.Server.Compression
|
|
import Test.Hspec
|
|
|
|
spec :: Spec
|
|
spec = describe "serialized data compression" $ parallel do
|
|
describe "getAcceptedEncodings" do
|
|
it "detects gzip and not" do
|
|
getAcceptedEncodings [("x", "x"), ("accept-encoding", "gzip")]
|
|
`shouldBe` Set.fromList [Just CTGZip, identityEncoding]
|
|
|
|
getAcceptedEncodings [("accept-encoding", "brotli, gzip;q=0.9")]
|
|
`shouldBe` Set.fromList [Just CTGZip, identityEncoding]
|
|
|
|
getAcceptedEncodings [("accept-encoding", "brotli")]
|
|
`shouldBe` Set.fromList [identityEncoding]
|
|
|
|
getAcceptedEncodings [("accept-encoding", "identity;q=0.42,brotli, gzip;q=0.9")]
|
|
`shouldBe` Set.fromList [Just CTGZip, identityEncoding]
|
|
|
|
getAcceptedEncodings [("accept-encoding", "identity;q=0.42,brotli, gzip;q=0")]
|
|
`shouldBe` Set.fromList [identityEncoding]
|
|
|
|
it "handles explicit rejection of identity" do
|
|
getAcceptedEncodings [("accept-encoding", "identity;q=0,brotli, gzip;q=0.9")]
|
|
`shouldBe` Set.fromList [Just CTGZip]
|
|
|
|
-- strictly per spec this would result in a 406, but we'll likely
|
|
-- just decide to return uncompressed (identity) higher up
|
|
getAcceptedEncodings [("accept-encoding", "identity;q=0,brotli")]
|
|
`shouldBe` Set.fromList []
|
|
getAcceptedEncodings [("accept-encoding", "*;q=0,brotli")]
|
|
`shouldBe` Set.fromList []
|
|
|
|
getAcceptedEncodings [("accept-encoding", "gzip, *;q=0")]
|
|
`shouldBe` Set.fromList [Just CTGZip]
|
|
|
|
-- behaviors that might change if we decide it's worth it:
|
|
it "arbitrary/historical behavior" do
|
|
-- see Compression.hs for discussion
|
|
getAcceptedEncodings [("accept-encoding", "*")]
|
|
`shouldBe` Set.fromList [identityEncoding]
|
|
getAcceptedEncodings []
|
|
`shouldBe` Set.fromList [identityEncoding]
|
|
getAcceptedEncodings [("accept-encoding", "")]
|
|
`shouldBe` Set.fromList [identityEncoding]
|
|
|
|
describe "compressResponse" do
|
|
let smallVal = "xxxx"
|
|
largeVal = BL.pack $ replicate 1000 121
|
|
|
|
it "compresses when required" do
|
|
let (valOut0, encodingChosen0) = compressResponse [("accept-encoding", "gzip, identity;q=0")] smallVal
|
|
GZ.decompress valOut0 `shouldBe` smallVal
|
|
encodingChosen0 `shouldBe` Just CTGZip
|
|
|
|
let (valOut1, encodingChosen1) = compressResponse [("accept-encoding", "gzip, identity;q=0")] largeVal
|
|
GZ.decompress valOut1 `shouldBe` largeVal
|
|
encodingChosen1 `shouldBe` Just CTGZip
|
|
|
|
it "omits compression for small values" do
|
|
let (valOut0, encodingChosen0) = compressResponse [("accept-encoding", "gzip")] smallVal
|
|
valOut0 `shouldBe` smallVal
|
|
encodingChosen0 `shouldBe` Nothing
|
|
|
|
let (valOut1, encodingChosen1) = compressResponse [("accept-encoding", "gzip")] largeVal
|
|
GZ.decompress valOut1 `shouldBe` largeVal
|
|
encodingChosen1 `shouldBe` Just CTGZip
|