Skip to content

Commit

Permalink
implement full retry of partial failures in firehose/streams
Browse files Browse the repository at this point in the history
  • Loading branch information
dengmingtong committed May 30, 2023
1 parent f224f6c commit e11a090
Show file tree
Hide file tree
Showing 6 changed files with 7 additions and 6 deletions.
2 changes: 1 addition & 1 deletion src/sinks/aws_kinesis/firehose/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -193,7 +193,7 @@ impl RetryLogic for KinesisRetryLogic {
let msg = format!("partial error count {}", response.failure_count);
return RetryAction::Retry(msg.into());
} else {
RetryAction::Successful
return RetryAction::Successful
}
}
}
1 change: 1 addition & 0 deletions src/sinks/aws_kinesis/firehose/integration_tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@ async fn firehose_put_records() {
tls: None,
auth: Default::default(),
acknowledgements: Default::default(),
request_retry_partial: Default::default(),
};

let config = KinesisFirehoseSinkConfig { batch, base };
Expand Down
2 changes: 1 addition & 1 deletion src/sinks/aws_kinesis/firehose/record.rs
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ impl SendRecord for KinesisFirehoseClient {
records: Vec<Self::T>,
stream_name: String,
) -> Result<KinesisResponse, SdkError<Self::E>> {
let rec_count = records.len().clone();
let rec_count = records.len();

self.client
.put_record_batch()
Expand Down
2 changes: 1 addition & 1 deletion src/sinks/aws_kinesis/streams/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -206,7 +206,7 @@ impl RetryLogic for KinesisRetryLogic {
let msg = format!("partial error count {}", response.failure_count);
return RetryAction::Retry(msg.into());
} else {
RetryAction::Successful
return RetryAction::Successful
}
}
}
Expand Down
1 change: 1 addition & 0 deletions src/sinks/aws_kinesis/streams/integration_tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,7 @@ async fn kinesis_put_records_without_partition_key() {
tls: Default::default(),
auth: Default::default(),
acknowledgements: Default::default(),
request_retry_partial: Default::default(),
};

let config = KinesisStreamsSinkConfig {
Expand Down
5 changes: 2 additions & 3 deletions src/sinks/aws_kinesis/streams/record.rs
Original file line number Diff line number Diff line change
@@ -1,10 +1,9 @@
use crate::sinks::aws_kinesis::KinesisResponse;
use aws_sdk_kinesis::output::PutRecordsOutput;
use aws_sdk_kinesis::types::{Blob, SdkError};
use bytes::Bytes;
use tracing::Instrument;

use super::{KinesisClient, KinesisError, KinesisRecord, Record, SendRecord};
use super::{KinesisClient, KinesisError, KinesisResponse, KinesisRecord, Record, SendRecord};

#[derive(Clone)]
pub struct KinesisStreamRecord {
Expand Down Expand Up @@ -69,7 +68,7 @@ impl SendRecord for KinesisStreamClient {
records: Vec<Self::T>,
stream_name: String,
) -> Result<KinesisResponse, SdkError<Self::E>> {
let rec_count = records.len().clone();
let rec_count = records.len();
self.client
.put_records()
.set_records(Some(records))
Expand Down

0 comments on commit e11a090

Please sign in to comment.