chore: A/B test 5

This commit is contained in:
ThetaDev 2023-05-01 18:39:29 +02:00
parent 20ecea65ef
commit fa4c845c2f
5 changed files with 94 additions and 53365 deletions

View file

@ -1,3 +1,5 @@
use std::collections::BTreeMap;
use anyhow::{bail, Result};
use futures::{stream, StreamExt};
use indicatif::{ProgressBar, ProgressStyle};
@ -5,6 +7,7 @@ use num_enum::TryFromPrimitive;
use rustypipe::client::{ClientType, RustyPipe, YTContext};
use rustypipe::model::YouTubeItem;
use rustypipe::param::search_filter::{ItemType, SearchFilter};
use serde::de::IgnoredAny;
use serde::{Deserialize, Serialize};
#[derive(
@ -16,6 +19,7 @@ pub enum ABTest {
ThreeTabChannelLayout = 2,
ChannelHandlesInSearchResults = 3,
TrendsVideoTab = 4,
TrendsPageHeaderRenderer = 5,
}
const TESTS_TO_RUN: [ABTest; 1] = [ABTest::TrendsVideoTab];
@ -82,6 +86,9 @@ pub async fn run_test(
channel_handles_in_search_results(&rp, &visitor_data).await
}
ABTest::TrendsVideoTab => trends_video_tab(&rp, &visitor_data).await,
ABTest::TrendsPageHeaderRenderer => {
trends_page_header_renderer(&rp, &visitor_data).await
}
}
.unwrap();
pb.inc(1);
@ -200,3 +207,28 @@ pub async fn trends_video_tab(rp: &RustyPipe, visitor_data: &str) -> Result<bool
Ok(res.contains("\"4gIOGgxtb3N0X3BvcHVsYXI%3D\""))
}
pub async fn trends_page_header_renderer(rp: &RustyPipe, visitor_data: &str) -> Result<bool> {
let query = rp.query().visitor_data(visitor_data);
let context = query.get_context(ClientType::Desktop, true, None).await;
let res = query
.raw(
ClientType::Desktop,
"browse",
&QBrowse {
context,
browse_id: "FEtrending",
params: None,
},
)
.await?;
#[derive(Debug, Deserialize)]
struct D {
header: BTreeMap<String, IgnoredAny>,
}
let data = serde_json::from_str::<D>(&res)?;
Ok(data.header.contains_key("pageHeaderRenderer"))
}

View file

@ -290,3 +290,58 @@ The data model for the video shelves did not change.
**NEW**
![A/B test 4 old screenshot](./_img/ab_4_new.png)
## [5] Page header renderer on the Trending page
- **Encountered on:** 1.05.2023
- **Impact:** 🟢 Low
- **Endpoint:** browse (trending videos)
YouTube changed the header renderer type on the trending page to a `pageHeaderRenderer`.
**OLD**
```json
"c4TabbedHeaderRenderer": {
"avatar": {
"thumbnails": [
{
"height": 100,
"url": "https://www.youtube.com/img/trending/avatar/trending_avatar.png",
"width": 100
}
]
},
"title": "Trending",
"trackingParams": "CBAQ8DsiEwiXi_iUht76AhVM6hEIHfgTB2g="
}
```
**NEW**
```json
"pageHeaderRenderer": {
"pageTitle": "Trending",
"content": {
"pageHeaderViewModel": {
"title": {
"dynamicTextViewModel": { "text": { "content": "Trending" } }
},
"image": {
"contentPreviewImageViewModel": {
"image": {
"sources": [
{
"url": "https://www.youtube.com/img/trending/avatar/trending.png",
"width": 100,
"height": 100
}
]
},
"style": "CONTENT_PREVIEW_IMAGE_STYLE_CIRCLE"
}
}
}
}
}
```

View file

@ -124,6 +124,7 @@ mod tests {
use std::{fs::File, io::BufReader};
use path_macro::path;
use rstest::rstest;
use crate::{
client::{response, MapResponse},
@ -154,9 +155,11 @@ mod tests {
});
}
#[test]
fn map_trending() {
let json_path = path!(*TESTFILES / "trends" / "trending.json");
#[rstest]
#[case::base("videos")]
#[case::page_header_renderer("20230501_page_header_renderer")]
fn map_trending(#[case] name: &str) {
let json_path = path!(*TESTFILES / "trends" / format!("trending_{name}.json"));
let json_file = File::open(json_path).unwrap();
let startpage: response::Trending =
@ -170,7 +173,7 @@ mod tests {
map_res.warnings
);
insta::assert_ron_snapshot!("map_trending", map_res.c, {
insta::assert_ron_snapshot!(format!("map_trending_{name}"), map_res.c, {
"[].publish_date" => "[date]",
});
}

File diff suppressed because it is too large Load diff