// Copyright 2015-2019 Parity Technologies (UK) Ltd. // This file is part of Parity Ethereum. // Parity Ethereum is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // Parity Ethereum is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // You should have received a copy of the GNU General Public License // along with Parity Ethereum. If not, see . extern crate fetch; extern crate futures; extern crate hyper; use fetch::{Fetch, Request, Url}; use futures::{future, future::FutureResult}; use hyper::{Body, StatusCode}; #[derive(Clone, Default)] pub struct FakeFetch where T: Clone + Send + Sync, { val: Option, } impl FakeFetch where T: Clone + Send + Sync, { pub fn new(t: Option) -> Self { FakeFetch { val: t } } } impl Fetch for FakeFetch where T: Clone + Send + Sync, { type Result = FutureResult; fn fetch(&self, request: Request, abort: fetch::Abort) -> Self::Result { let u = request.url().clone(); future::ok(if self.val.is_some() { let r = hyper::Response::new("Some content".into()); fetch::client::Response::new(u, r, abort) } else { let r = hyper::Response::builder() .status(StatusCode::NOT_FOUND) .body(Body::empty()) .expect("Nothing to parse, can not fail; qed"); fetch::client::Response::new(u, r, abort) }) } fn get(&self, url: &str, abort: fetch::Abort) -> Self::Result { let url: Url = match url.parse() { Ok(u) => u, Err(e) => return future::err(e.into()), }; self.fetch(Request::get(url), abort) } fn post(&self, url: &str, abort: fetch::Abort) -> Self::Result { let url: Url = match url.parse() { Ok(u) => u, Err(e) => return future::err(e.into()), }; self.fetch(Request::post(url), abort) } }