161 lines
4.7 KiB
Rust
161 lines
4.7 KiB
Rust
#[macro_use]
|
|
extern crate criterion;
|
|
use criterion::Criterion;
|
|
|
|
extern crate futures;
|
|
extern crate hammond_data;
|
|
extern crate hyper;
|
|
extern crate hyper_tls;
|
|
extern crate rand;
|
|
extern crate tokio_core;
|
|
// extern crate rayon;
|
|
extern crate rss;
|
|
|
|
// use rayon::prelude::*;
|
|
|
|
use futures::future::*;
|
|
use tokio_core::reactor::Core;
|
|
|
|
use hammond_data::Source;
|
|
use hammond_data::database::truncate_db;
|
|
use hammond_data::errors::*;
|
|
use hammond_data::feed::*;
|
|
|
|
use std::io::BufReader;
|
|
|
|
// Big rss feed
|
|
const PCPER: &[u8] = include_bytes!("feeds/pcpermp3.xml");
|
|
const UNPLUGGED: &[u8] = include_bytes!("feeds/linuxunplugged.xml");
|
|
const RADIO: &[u8] = include_bytes!("feeds/coderradiomp3.xml");
|
|
const SNAP: &[u8] = include_bytes!("feeds/techsnapmp3.xml");
|
|
const LAS: &[u8] = include_bytes!("feeds/TheLinuxActionShow.xml");
|
|
|
|
// This feed has HUGE descripion and summary fields which can be very
|
|
// very expensive to parse.
|
|
const CODE: &[u8] = include_bytes!("feeds/GreaterThanCode.xml");
|
|
// Relative small feed
|
|
const STARS: &[u8] = include_bytes!("feeds/StealTheStars.xml");
|
|
|
|
static URLS: &[(&[u8], &str)] = &[
|
|
(PCPER, "https://www.pcper.com/rss/podcasts-mp3.rss"),
|
|
(UNPLUGGED, "http://feeds.feedburner.com/linuxunplugged"),
|
|
(RADIO, "https://feeds.feedburner.com/coderradiomp3"),
|
|
(SNAP, "https://feeds.feedburner.com/techsnapmp3"),
|
|
(LAS, "https://feeds2.feedburner.com/TheLinuxActionShow"),
|
|
];
|
|
|
|
fn index_urls() {
|
|
let feeds: Vec<_> = URLS.iter()
|
|
.map(|&(buff, url)| {
|
|
// Create and insert a Source into db
|
|
let s = Source::from_url(url).unwrap();
|
|
// parse it into a channel
|
|
let chan = rss::Channel::read_from(BufReader::new(buff)).unwrap();
|
|
Feed::from_channel_source(chan, s.id())
|
|
})
|
|
.collect();
|
|
|
|
feeds.iter().for_each(|x| x.index().unwrap());
|
|
}
|
|
|
|
fn index_urls_async() -> Vec<Box<Future<Item = (), Error = Error>>> {
|
|
let feeds: Vec<_> = URLS.iter()
|
|
.map(|&(buff, url)| {
|
|
// Create and insert a Source into db
|
|
let s = Source::from_url(url).unwrap();
|
|
// parse it into a channel
|
|
let chan = rss::Channel::read_from(BufReader::new(buff)).unwrap();
|
|
Feed::from_channel_source(chan, s.id())
|
|
})
|
|
.collect();
|
|
|
|
feeds.into_iter().map(|feed| feed.index_async()).collect()
|
|
}
|
|
|
|
fn bench_index_feeds(c: &mut Criterion) {
|
|
truncate_db().unwrap();
|
|
|
|
c.bench_function("index_feeds_sync", |b| b.iter(|| index_urls()));
|
|
}
|
|
|
|
fn bench_index_feeds_async(c: &mut Criterion) {
|
|
truncate_db().unwrap();
|
|
let mut core = Core::new().unwrap();
|
|
|
|
c.bench_function("index_feeds_sync", |b| {
|
|
b.iter(|| {
|
|
let list = index_urls_async();
|
|
let _foo = core.run(select_all(list));
|
|
})
|
|
});
|
|
}
|
|
|
|
fn bench_index_unchanged_feeds(c: &mut Criterion) {
|
|
truncate_db().unwrap();
|
|
// Index first so it will only bench the comparison test case.
|
|
index_urls();
|
|
|
|
c.bench_function("index_10_unchanged_sync", |b| {
|
|
b.iter(|| {
|
|
for _ in 0..10 {
|
|
index_urls();
|
|
}
|
|
})
|
|
});
|
|
}
|
|
|
|
fn bench_get_future_feeds(c: &mut Criterion) {
|
|
truncate_db().unwrap();
|
|
URLS.iter().for_each(|&(_, url)| {
|
|
Source::from_url(url).unwrap();
|
|
});
|
|
|
|
c.bench_function("index_urls_futures", |b| {
|
|
b.iter(|| {
|
|
let sources = hammond_data::dbqueries::get_sources().unwrap();
|
|
hammond_data::pipeline::pipeline(sources, false).unwrap();
|
|
})
|
|
});
|
|
}
|
|
|
|
fn bench_index_greater_than_code(c: &mut Criterion) {
|
|
truncate_db().unwrap();
|
|
let url = "https://www.greaterthancode.com/feed/podcast";
|
|
|
|
c.bench_function("index_greater_than_code_sync", |b| {
|
|
b.iter(|| {
|
|
let s = Source::from_url(url).unwrap();
|
|
// parse it into a channel
|
|
let chan = rss::Channel::read_from(BufReader::new(CODE)).unwrap();
|
|
let feed = Feed::from_channel_source(chan, s.id());
|
|
feed.index().unwrap();
|
|
})
|
|
});
|
|
}
|
|
|
|
fn bench_index_steal_the_stars(c: &mut Criterion) {
|
|
truncate_db().unwrap();
|
|
let url = "https://rss.art19.com/steal-the-stars";
|
|
|
|
c.bench_function("index_steal_the_stars_sync", |b| {
|
|
b.iter(|| {
|
|
let s = Source::from_url(url).unwrap();
|
|
// parse it into a channel
|
|
let chan = rss::Channel::read_from(BufReader::new(STARS)).unwrap();
|
|
let feed = Feed::from_channel_source(chan, s.id());
|
|
feed.index().unwrap();
|
|
})
|
|
});
|
|
}
|
|
|
|
criterion_group!(
|
|
benches,
|
|
bench_index_feeds,
|
|
bench_index_feeds_async,
|
|
bench_index_unchanged_feeds,
|
|
bench_get_future_feeds,
|
|
bench_index_greater_than_code,
|
|
bench_index_steal_the_stars
|
|
);
|
|
criterion_main!(benches);
|