You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							102 lines
						
					
					
						
							2.9 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							102 lines
						
					
					
						
							2.9 KiB
						
					
					
				
								package mq_agent_pb
							 | 
						|
								
							 | 
						|
								import (
							 | 
						|
									"testing"
							 | 
						|
									"google.golang.org/protobuf/proto"
							 | 
						|
								)
							 | 
						|
								
							 | 
						|
								func TestPublishRecordResponseSerialization(t *testing.T) {
							 | 
						|
									// Test that PublishRecordResponse can serialize/deserialize with new offset fields
							 | 
						|
									original := &PublishRecordResponse{
							 | 
						|
										AckSequence: 123,
							 | 
						|
										Error:       "",
							 | 
						|
										BaseOffset:  1000, // New field
							 | 
						|
										LastOffset:  1005, // New field
							 | 
						|
									}
							 | 
						|
								
							 | 
						|
									// Test proto marshaling/unmarshaling
							 | 
						|
									data, err := proto.Marshal(original)
							 | 
						|
									if err != nil {
							 | 
						|
										t.Fatalf("Failed to marshal PublishRecordResponse: %v", err)
							 | 
						|
									}
							 | 
						|
								
							 | 
						|
									restored := &PublishRecordResponse{}
							 | 
						|
									err = proto.Unmarshal(data, restored)
							 | 
						|
									if err != nil {
							 | 
						|
										t.Fatalf("Failed to unmarshal PublishRecordResponse: %v", err)
							 | 
						|
									}
							 | 
						|
								
							 | 
						|
									// Verify all fields are preserved
							 | 
						|
									if restored.AckSequence != original.AckSequence {
							 | 
						|
										t.Errorf("AckSequence = %d, want %d", restored.AckSequence, original.AckSequence)
							 | 
						|
									}
							 | 
						|
									if restored.BaseOffset != original.BaseOffset {
							 | 
						|
										t.Errorf("BaseOffset = %d, want %d", restored.BaseOffset, original.BaseOffset)
							 | 
						|
									}
							 | 
						|
									if restored.LastOffset != original.LastOffset {
							 | 
						|
										t.Errorf("LastOffset = %d, want %d", restored.LastOffset, original.LastOffset)
							 | 
						|
									}
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								func TestSubscribeRecordResponseSerialization(t *testing.T) {
							 | 
						|
									// Test that SubscribeRecordResponse can serialize/deserialize with new offset field
							 | 
						|
									original := &SubscribeRecordResponse{
							 | 
						|
										Key:           []byte("test-key"),
							 | 
						|
										TsNs:          1234567890,
							 | 
						|
										Error:         "",
							 | 
						|
										IsEndOfStream: false,
							 | 
						|
										IsEndOfTopic:  false,
							 | 
						|
										Offset:        42, // New field
							 | 
						|
									}
							 | 
						|
								
							 | 
						|
									// Test proto marshaling/unmarshaling
							 | 
						|
									data, err := proto.Marshal(original)
							 | 
						|
									if err != nil {
							 | 
						|
										t.Fatalf("Failed to marshal SubscribeRecordResponse: %v", err)
							 | 
						|
									}
							 | 
						|
								
							 | 
						|
									restored := &SubscribeRecordResponse{}
							 | 
						|
									err = proto.Unmarshal(data, restored)
							 | 
						|
									if err != nil {
							 | 
						|
										t.Fatalf("Failed to unmarshal SubscribeRecordResponse: %v", err)
							 | 
						|
									}
							 | 
						|
								
							 | 
						|
									// Verify all fields are preserved
							 | 
						|
									if restored.TsNs != original.TsNs {
							 | 
						|
										t.Errorf("TsNs = %d, want %d", restored.TsNs, original.TsNs)
							 | 
						|
									}
							 | 
						|
									if restored.Offset != original.Offset {
							 | 
						|
										t.Errorf("Offset = %d, want %d", restored.Offset, original.Offset)
							 | 
						|
									}
							 | 
						|
									if string(restored.Key) != string(original.Key) {
							 | 
						|
										t.Errorf("Key = %s, want %s", string(restored.Key), string(original.Key))
							 | 
						|
									}
							 | 
						|
								}
							 | 
						|
								
							 | 
						|
								func TestPublishRecordResponseBackwardCompatibility(t *testing.T) {
							 | 
						|
									// Test that PublishRecordResponse without offset fields still works
							 | 
						|
									original := &PublishRecordResponse{
							 | 
						|
										AckSequence: 123,
							 | 
						|
										Error:       "",
							 | 
						|
										// BaseOffset and LastOffset not set (defaults to 0)
							 | 
						|
									}
							 | 
						|
								
							 | 
						|
									data, err := proto.Marshal(original)
							 | 
						|
									if err != nil {
							 | 
						|
										t.Fatalf("Failed to marshal PublishRecordResponse: %v", err)
							 | 
						|
									}
							 | 
						|
								
							 | 
						|
									restored := &PublishRecordResponse{}
							 | 
						|
									err = proto.Unmarshal(data, restored)
							 | 
						|
									if err != nil {
							 | 
						|
										t.Fatalf("Failed to unmarshal PublishRecordResponse: %v", err)
							 | 
						|
									}
							 | 
						|
								
							 | 
						|
									// Offset fields should default to 0
							 | 
						|
									if restored.BaseOffset != 0 {
							 | 
						|
										t.Errorf("BaseOffset = %d, want 0", restored.BaseOffset)
							 | 
						|
									}
							 | 
						|
									if restored.LastOffset != 0 {
							 | 
						|
										t.Errorf("LastOffset = %d, want 0", restored.LastOffset)
							 | 
						|
									}
							 | 
						|
								}
							 |