|
1 | 1 | package types |
2 | 2 |
|
3 | 3 | import ( |
| 4 | + "bytes" |
4 | 5 | "crypto/rand" |
5 | 6 | "testing" |
6 | 7 | "time" |
@@ -355,6 +356,53 @@ func TestHeader_HashFields_NilAndEmpty(t *testing.T) { |
355 | 356 | assert.Nil(t, h2.ValidatorHash) |
356 | 357 | } |
357 | 358 |
|
| 359 | +func TestHeaderMarshalBinary_PreservesLegacyFields(t *testing.T) { |
| 360 | + t.Parallel() |
| 361 | + |
| 362 | + header := &Header{ |
| 363 | + Version: Version{Block: 2, App: 3}, |
| 364 | + BaseHeader: BaseHeader{Height: 42, Time: 123456789, ChainID: "chain-legacy"}, |
| 365 | + LastHeaderHash: []byte{ |
| 366 | + 0x01, 0x02, 0x03, 0x04, |
| 367 | + }, |
| 368 | + DataHash: []byte{0x05, 0x06, 0x07, 0x08}, |
| 369 | + AppHash: []byte{0x09, 0x0A, 0x0B, 0x0C}, |
| 370 | + ProposerAddress: []byte{0x0D, 0x0E, 0x0F, 0x10}, |
| 371 | + ValidatorHash: []byte{0x11, 0x12, 0x13, 0x14}, |
| 372 | + Legacy: &LegacyHeaderFields{ |
| 373 | + LastCommitHash: bytes.Repeat([]byte{0x21}, 32), |
| 374 | + ConsensusHash: bytes.Repeat([]byte{0x22}, 32), |
| 375 | + LastResultsHash: bytes.Repeat([]byte{0x23}, 32), |
| 376 | + }, |
| 377 | + } |
| 378 | + |
| 379 | + unknown := header.ToProto().ProtoReflect().GetUnknown() |
| 380 | + require.NotEmpty(t, unknown, "legacy fields should be serialized into unknown proto fields") |
| 381 | + |
| 382 | + raw, err := header.MarshalBinary() |
| 383 | + require.NoError(t, err) |
| 384 | + require.NotEmpty(t, raw) |
| 385 | + |
| 386 | + var decoded Header |
| 387 | + require.NoError(t, decoded.UnmarshalBinary(raw)) |
| 388 | + require.NotNil(t, decoded.Legacy) |
| 389 | + require.False(t, decoded.Legacy.IsZero()) |
| 390 | + |
| 391 | + assert.Equal(t, header.Legacy.LastCommitHash, decoded.Legacy.LastCommitHash) |
| 392 | + assert.Equal(t, header.Legacy.ConsensusHash, decoded.Legacy.ConsensusHash) |
| 393 | + assert.Equal(t, header.Legacy.LastResultsHash, decoded.Legacy.LastResultsHash) |
| 394 | + |
| 395 | + origHash := header.Hash() |
| 396 | + decodedHash := decoded.Hash() |
| 397 | + require.NotNil(t, origHash) |
| 398 | + require.NotNil(t, decodedHash) |
| 399 | + assert.Equal(t, origHash, decodedHash) |
| 400 | + |
| 401 | + legacyHash, err := header.HashLegacy() |
| 402 | + require.NoError(t, err) |
| 403 | + assert.Equal(t, legacyHash, origHash) |
| 404 | +} |
| 405 | + |
358 | 406 | // TestProtoConversionConsistency_AllTypes checks that ToProto/FromProto are true inverses for all major types. |
359 | 407 | func TestProtoConversionConsistency_AllTypes(t *testing.T) { |
360 | 408 | // Header |
|
0 commit comments