Fix up cargo test --no-default-features. (#75)

Adds some feature guards, and removes an unnecessary feature guard
around a call to connect_https (there's an implementation available for
non-TLS that returns UnknownScheme).

Also, remove unnecessary agent.state() method that was only available in
TLS builds. The state field is directly accessible within the crate, and
can be used in both TLS and non-TLS builds.

Co-authored-by: Martin Algesten <martin@algesten.se>
This commit is contained in:
Jacob Hoffman-Andrews
2020-06-21 00:54:03 -07:00
committed by GitHub
parent e366c8fcd0
commit 7adbd57308
7 changed files with 13 additions and 18 deletions

View File

@@ -249,11 +249,6 @@ impl Agent {
pub fn patch(&self, path: &str) -> Request { pub fn patch(&self, path: &str) -> Request {
self.request("PATCH", path) self.request("PATCH", path)
} }
#[cfg(all(test, any(feature = "tls", feature = "native-tls")))]
pub(crate) fn state(&self) -> &Arc<Mutex<Option<AgentState>>> {
&self.state
}
} }
pub(crate) fn basic_auth(user: &str, pass: &str) -> String { pub(crate) fn basic_auth(user: &str, pass: &str) -> String {

View File

@@ -29,7 +29,7 @@ impl ConnectionPool {
self.recycle.remove(&PoolKey::new(url)) self.recycle.remove(&PoolKey::new(url))
} }
#[cfg(all(test, any(feature = "tls", feature = "native-tls")))] #[cfg(test)]
pub fn len(&self) -> usize { pub fn len(&self) -> usize {
self.recycle.len() self.recycle.len()
} }

View File

@@ -218,9 +218,11 @@ impl Response {
/// Example: /// Example:
/// ///
/// ``` /// ```
/// # #[cfg(feature = "tls")] {
/// let resp = ureq::get("https://www.google.com/").call(); /// let resp = ureq::get("https://www.google.com/").call();
/// assert_eq!("text/html; charset=ISO-8859-1", resp.header("content-type").unwrap()); /// assert_eq!("text/html; charset=ISO-8859-1", resp.header("content-type").unwrap());
/// assert_eq!("text/html", resp.content_type()); /// assert_eq!("text/html", resp.content_type());
/// # }
/// ``` /// ```
pub fn content_type(&self) -> &str { pub fn content_type(&self) -> &str {
self.header("content-type") self.header("content-type")
@@ -238,9 +240,11 @@ impl Response {
/// Example: /// Example:
/// ///
/// ``` /// ```
/// # #[cfg(feature = "tls")] {
/// let resp = ureq::get("https://www.google.com/").call(); /// let resp = ureq::get("https://www.google.com/").call();
/// assert_eq!("text/html; charset=ISO-8859-1", resp.header("content-type").unwrap()); /// assert_eq!("text/html; charset=ISO-8859-1", resp.header("content-type").unwrap());
/// assert_eq!("ISO-8859-1", resp.charset()); /// assert_eq!("ISO-8859-1", resp.charset());
/// # }
/// ``` /// ```
pub fn charset(&self) -> &str { pub fn charset(&self) -> &str {
charset_from_content_type(self.header("content-type")) charset_from_content_type(self.header("content-type"))
@@ -257,6 +261,7 @@ impl Response {
/// Example: /// Example:
/// ///
/// ``` /// ```
/// # #[cfg(feature = "tls")] {
/// use std::io::Read; /// use std::io::Read;
/// ///
/// let resp = /// let resp =
@@ -272,6 +277,7 @@ impl Response {
/// reader.read_to_end(&mut bytes); /// reader.read_to_end(&mut bytes);
/// ///
/// assert_eq!(bytes.len(), len); /// assert_eq!(bytes.len(), len);
/// # }
/// ``` /// ```
pub fn into_reader(self) -> impl Read { pub fn into_reader(self) -> impl Read {
// //
@@ -331,6 +337,7 @@ impl Response {
/// Example: /// Example:
/// ///
/// ``` /// ```
/// # #[cfg(feature = "tls")] {
/// let resp = /// let resp =
/// ureq::get("https://ureq.s3.eu-central-1.amazonaws.com/hello_world.json") /// ureq::get("https://ureq.s3.eu-central-1.amazonaws.com/hello_world.json")
/// .call(); /// .call();
@@ -338,6 +345,7 @@ impl Response {
/// let text = resp.into_string().unwrap(); /// let text = resp.into_string().unwrap();
/// ///
/// assert!(text.contains("hello")); /// assert!(text.contains("hello"));
/// # }
/// ``` /// ```
/// ///
/// ## Charset support /// ## Charset support

View File

@@ -193,6 +193,7 @@ where
} }
} }
#[cfg(all(feature = "tls", not(feature = "native-tls")))]
fn read_https( fn read_https(
stream: &mut StreamOwned<ClientSession, TcpStream>, stream: &mut StreamOwned<ClientSession, TcpStream>,
buf: &mut [u8], buf: &mut [u8],

View File

@@ -99,7 +99,7 @@ fn connection_reuse() {
resp.into_reader().read_to_end(&mut buf).unwrap(); resp.into_reader().read_to_end(&mut buf).unwrap();
{ {
let mut guard_state = agent.state().lock().unwrap(); let mut guard_state = agent.state.lock().unwrap();
let mut state = guard_state.take().unwrap(); let mut state = guard_state.take().unwrap();
assert!(state.pool().len() > 0); assert!(state.pool().len() > 0);
} }

View File

@@ -39,7 +39,7 @@ fn agent_pool() {
assert_eq!(len, 1000); assert_eq!(len, 1000);
{ {
let mut lock = agent.state().lock().unwrap(); let mut lock = agent.state.lock().unwrap();
let state = lock.as_mut().unwrap(); let state = lock.as_mut().unwrap();
let pool = state.pool(); let pool = state.pool();
assert_eq!(pool.len(), 1); assert_eq!(pool.len(), 1);

View File

@@ -11,11 +11,6 @@ use cookie::{Cookie, CookieJar};
use crate::agent::AgentState; use crate::agent::AgentState;
use crate::body::{self, Payload, SizedReader}; use crate::body::{self, Payload, SizedReader};
use crate::header; use crate::header;
#[cfg(any(
all(feature = "tls", not(feature = "native-tls")),
all(feature = "native-tls", not(feature = "tls")),
))]
use crate::stream::connect_https;
use crate::stream::{self, connect_test, Stream}; use crate::stream::{self, connect_test, Stream};
use crate::Proxy; use crate::Proxy;
use crate::{Error, Header, Request, Response}; use crate::{Error, Header, Request, Response};
@@ -303,11 +298,7 @@ fn connect_socket(unit: &Unit, use_pooled: bool) -> Result<(Stream, bool), Error
} }
let stream = match unit.url.scheme() { let stream = match unit.url.scheme() {
"http" => stream::connect_http(&unit), "http" => stream::connect_http(&unit),
#[cfg(any( "https" => stream::connect_https(&unit),
all(feature = "tls", not(feature = "native-tls")),
all(feature = "native-tls", not(feature = "tls")),
))]
"https" => connect_https(&unit),
"test" => connect_test(&unit), "test" => connect_test(&unit),
_ => Err(Error::UnknownScheme(unit.url.scheme().to_string())), _ => Err(Error::UnknownScheme(unit.url.scheme().to_string())),
}; };