-
Notifications
You must be signed in to change notification settings - Fork 483
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
PLT-8912: Fix unsafety in the "safe" Data decoding code (#5671)
* Add test for decoding the problematic data object * Fix unsafe decoding bug * changelog * Use CBOR instead
- Loading branch information
Showing
11 changed files
with
94 additions
and
25 deletions.
There are no files selected for viewing
32 changes: 16 additions & 16 deletions
32
plutus-benchmark/ed25519-costs/test/9.6/ed25519-costs.golden
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,20 +1,20 @@ | ||
n Script size CPU usage Memory usage | ||
---------------------------------------------------------------------- | ||
0 431 (2.6%) 5309576 (0.1%) 20058 (0.1%) | ||
10 2158 (13.2%) 723602616 (7.2%) 488248 (3.5%) | ||
20 3885 (23.7%) 1441895656 (14.4%) 956438 (6.8%) | ||
30 5612 (34.3%) 2160188696 (21.6%) 1424628 (10.2%) | ||
40 7339 (44.8%) 2878481736 (28.8%) 1892818 (13.5%) | ||
50 9065 (55.3%) 3596774776 (36.0%) 2361008 (16.9%) | ||
60 10792 (65.9%) 4315067816 (43.2%) 2829198 (20.2%) | ||
70 12519 (76.4%) 5033360856 (50.3%) 3297388 (23.6%) | ||
80 14245 (86.9%) 5751653896 (57.5%) 3765578 (26.9%) | ||
90 15972 (97.5%) 6469946936 (64.7%) 4233768 (30.2%) | ||
100 17699 (108.0%) 7188239976 (71.9%) 4701958 (33.6%) | ||
110 19426 (118.6%) 7906533016 (79.1%) 5170148 (36.9%) | ||
120 21152 (129.1%) 8624826056 (86.2%) 5638338 (40.3%) | ||
130 22879 (139.6%) 9343119096 (93.4%) 6106528 (43.6%) | ||
140 24606 (150.2%) 10061412136 (100.6%) 6574718 (47.0%) | ||
150 26333 (160.7%) 10779705176 (107.8%) 7042908 (50.3%) | ||
0 481 (2.9%) 6124112 (0.1%) 22722 (0.2%) | ||
10 2208 (13.5%) 732562512 (7.3%) 517552 (3.7%) | ||
20 3935 (24.0%) 1459000912 (14.6%) 1012382 (7.2%) | ||
30 5662 (34.6%) 2185439312 (21.9%) 1507212 (10.8%) | ||
40 7389 (45.1%) 2911877712 (29.1%) 2002042 (14.3%) | ||
50 9115 (55.6%) 3638316112 (36.4%) 2496872 (17.8%) | ||
60 10842 (66.2%) 4364754512 (43.6%) 2991702 (21.4%) | ||
70 12569 (76.7%) 5091192912 (50.9%) 3486532 (24.9%) | ||
80 14295 (87.2%) 5817631312 (58.2%) 3981362 (28.4%) | ||
90 16022 (97.8%) 6544069712 (65.4%) 4476192 (32.0%) | ||
100 17749 (108.3%) 7270508112 (72.7%) 4971022 (35.5%) | ||
110 19476 (118.9%) 7996946512 (80.0%) 5465852 (39.0%) | ||
120 21202 (129.4%) 8723384912 (87.2%) 5960682 (42.6%) | ||
130 22929 (139.9%) 9449823312 (94.5%) 6455512 (46.1%) | ||
140 24656 (150.5%) 10176261712 (101.8%) 6950342 (49.6%) | ||
150 26383 (161.0%) 10902700112 (109.0%) 7445172 (53.2%) | ||
|
||
Off-chain version succeeded on 100 inputs |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
{-# LANGUAGE TypeApplications #-} | ||
module Spec.ContextDecoding where | ||
|
||
import Codec.Serialise qualified as S | ||
import Data.ByteString.Lazy as BSL | ||
import Data.Maybe | ||
import PlutusCore.Data | ||
import PlutusLedgerApi.V1 qualified as V1 | ||
import PlutusLedgerApi.V2 qualified as V2 | ||
import PlutusLedgerApi.V3 qualified as V3 | ||
import PlutusTx.IsData | ||
import Test.Tasty | ||
import Test.Tasty.HUnit | ||
|
||
tests :: TestTree | ||
tests = testGroup "context decoding" [ test_v1Context ] | ||
|
||
test_v1Context :: TestTree | ||
test_v1Context = testCase "v1context" $ do | ||
input <- BSL.readFile "test/Spec/v1-context-data" | ||
let (d :: Data) = S.deserialise input | ||
assertBool "can't parse as V1 context" | ||
(isJust $ fromBuiltinData @V1.ScriptContext (V1.BuiltinData d)) | ||
-- Note, these should return Nothing and not throw | ||
assertBool "can parse as V2 context" | ||
(isNothing $ fromBuiltinData @V2.ScriptContext (V2.BuiltinData d)) | ||
assertBool "can parse as V3 context" | ||
(isNothing $ fromBuiltinData @V3.ScriptContext (V3.BuiltinData d)) |
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1 @@ | ||
320 | ||
349 |
4 changes: 4 additions & 0 deletions
4
plutus-tx/changelog.d/20231208_144400_michael.peyton-jones_fromData_bugs.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
### Fixed | ||
|
||
- The "safe" version of `fromData` was using an unsafe `head` function, so would | ||
crash on some malformed input instead of returning `Nothing`. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters