Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

logger: adjust logger to receive logs blobs #1172

Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
40a3a79
codegen: removed the otel layer generation
iulianbarbu Aug 22, 2023
1339888
proto: updated logger proto file
iulianbarbu Aug 22, 2023
7615495
logger: add store_logs RPC impl
iulianbarbu Aug 22, 2023
12fea55
logger: fixed tests
iulianbarbu Aug 23, 2023
6f7c1da
logger: decreased the visibility for Log type
iulianbarbu Aug 23, 2023
616fe2b
logger: remove the unwrap
iulianbarbu Aug 23, 2023
a9c0bd5
proto/logger: differentiate between a fetched/stored log items
iulianbarbu Aug 23, 2023
4c46e57
logger: simplify tests
iulianbarbu Aug 24, 2023
c813a61
runtime: removed tracing/otel dependencies
iulianbarbu Aug 24, 2023
2411767
runtime: removed the tracing dependencies
iulianbarbu Aug 24, 2023
3bae7ab
codegen: cleanup tracing layers and tests
iulianbarbu Aug 24, 2023
9e0fb45
runtime/next: fix compilation
iulianbarbu Aug 24, 2023
fc255d6
logger: remove claim verification on store_logs
iulianbarbu Aug 24, 2023
b1ab984
logger: implemented from_stored for StoredLogItem convertion to Log
iulianbarbu Aug 24, 2023
093e223
codegen: readd a missing import
iulianbarbu Aug 24, 2023
35f737e
codegen: fix tests
iulianbarbu Aug 24, 2023
ceaa9ff
addressed P review
iulianbarbu Aug 24, 2023
2659387
logger: removed integration test comment
iulianbarbu Aug 24, 2023
bf9c9b8
logger/tests: remove the DeploymentPush claim scope
iulianbarbu Aug 24, 2023
5fb7053
address orhun feedback
iulianbarbu Aug 24, 2023
ae860f5
logger: fixed error message typo
iulianbarbu Aug 24, 2023
67781d4
address Johan review
iulianbarbu Aug 24, 2023
53e7369
logger/proto: remove dedup protobuf defs
iulianbarbu Aug 24, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
logger: decreased the visibility for Log type
  • Loading branch information
iulianbarbu committed Aug 23, 2023
commit 6f7c1da740d6cc75e96db431b77aafa0cb0edafb
8 changes: 4 additions & 4 deletions logger/src/dal.rs
Original file line number Diff line number Diff line change
Expand Up @@ -120,10 +120,10 @@ impl Dal for Sqlite {

#[derive(Clone, Debug, FromRow)]
pub struct Log {
pub deployment_id: String,
pub shuttle_service_name: String,
pub tx_timestamp: DateTime<Utc>,
pub data: Vec<u8>,
pub(crate) deployment_id: String,
pub(crate) shuttle_service_name: String,
pub(crate) tx_timestamp: DateTime<Utc>,
pub(crate) data: Vec<u8>,
}

impl From<Log> for LogItem {
Expand Down
22 changes: 12 additions & 10 deletions logger/tests/integration_tests.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,14 +2,16 @@ use std::{
io::{self},
net::{Ipv4Addr, SocketAddr},
sync::Mutex,
time::SystemTime,
};

use chrono::Utc;
use portpicker::pick_unused_port;
use pretty_assertions::assert_eq;
use prost_types::Timestamp;
use shuttle_common::claims::Scope;
use shuttle_common_tests::JwtScopesLayer;
use shuttle_logger::{Log, Service, Sqlite};
use shuttle_logger::{Service, Sqlite};
use shuttle_proto::logger::{
logger_client::LoggerClient, logger_server::LoggerServer, LogItem, LogsRequest,
StoreLogsRequest,
Expand Down Expand Up @@ -369,7 +371,7 @@ impl From<LogItem> for MinLogItem {
struct LoggerLayer {
deployment_id: String,
shuttle_service: String,
tx: UnboundedSender<Vec<Log>>,
tx: UnboundedSender<Vec<LogItem>>,
_logs_forwarding_task: JoinHandle<()>,
}

Expand All @@ -379,16 +381,16 @@ impl LoggerLayer {
shuttle_service: String,
mut client: LoggerClient<tonic::transport::Channel>,
) -> Self {
let (tx, mut rx): (UnboundedSender<Vec<Log>>, UnboundedReceiver<Vec<Log>>) =
tokio::sync::mpsc::unbounded_channel();
let (tx, mut rx): (
UnboundedSender<Vec<LogItem>>,
UnboundedReceiver<Vec<LogItem>>,
) = tokio::sync::mpsc::unbounded_channel();
let handle = tokio::task::spawn(async move {
while let Some(logs) = rx.recv().await {
// service_tx.broadcast(logs).await.expect("to not fail");
// Get the generated logs
let _ = client
.store_logs(Request::new(StoreLogsRequest {
logs: logs.into_iter().map(Into::into).collect(),
}))
.store_logs(Request::new(StoreLogsRequest { logs }))
.await
.unwrap()
.into_inner();
Expand All @@ -407,10 +409,10 @@ impl io::Write for LoggerLayer {
fn write(&mut self, buf: &[u8]) -> io::Result<usize> {
if self
.tx
.send(vec![Log {
.send(vec![LogItem {
deployment_id: self.deployment_id.clone(),
shuttle_service_name: self.shuttle_service.clone(),
tx_timestamp: Utc::now(),
service_name: self.shuttle_service.clone(),
tx_timestamp: Some(Timestamp::from(SystemTime::from(Utc::now()))),
data: buf.to_vec(),
}])
.is_ok()
Expand Down