mirror of
https://github.com/danbulant/robotparser-rs
synced 2026-05-19 20:38:51 +00:00
252 lines
6.3 KiB
Rust
252 lines
6.3 KiB
Rust
extern crate robotparser;
|
|
extern crate url;
|
|
|
|
use robotparser::RobotFileParser;
|
|
use std::time::Duration;
|
|
use url::Url;
|
|
|
|
const AGENT: &'static str = "test_robotparser";
|
|
|
|
fn robot_test(doc: &str, good_urls: Vec<&str>, bad_urls: Vec<&str>, agent: &str) {
|
|
let parser = RobotFileParser::new("http://www.baidu.com/robots.txt");
|
|
let lines: Vec<&str> = doc.split("\n").collect();
|
|
parser.parse(&lines);
|
|
for url in &good_urls {
|
|
assert!(parser.can_fetch(agent, url));
|
|
}
|
|
for url in &bad_urls {
|
|
assert!(!parser.can_fetch(agent, url));
|
|
}
|
|
}
|
|
|
|
|
|
fn robot_test_simple(doc: &str, good_urls: Vec<&str>, bad_urls: Vec<&str>) {
|
|
robot_test(doc, good_urls, bad_urls, AGENT);
|
|
}
|
|
|
|
|
|
#[test]
|
|
fn test_robots_txt_1() {
|
|
let doc = "\n\
|
|
User-agent: *\n\
|
|
Disallow: /cyberworld/map/ # This is an infinite virtual URL space\n\
|
|
Disallow: /tmp/ # these will soon disappear\n\
|
|
Disallow: /foo.html\n\
|
|
";
|
|
let good = vec!["/","/test.html"];
|
|
let bad = vec!["/cyberworld/map/index.html","/tmp/xxx","/foo.html"];
|
|
robot_test_simple(doc, good, bad);
|
|
}
|
|
|
|
|
|
#[test]
|
|
fn test_robots_txt_2() {
|
|
let doc = "\n\
|
|
# robots.txt for http://www.example.com/\n\
|
|
\n\
|
|
User-agent: *\n\
|
|
Disallow: /cyberworld/map/ # This is an infinite virtual URL space\n\
|
|
\n\
|
|
# Cybermapper knows where to go.\n\
|
|
User-agent: cybermapper\n\
|
|
Disallow:\n\
|
|
\n\
|
|
";
|
|
let good = vec!["/","/test.html"];
|
|
let bad = vec!["/cyberworld/map/index.html"];
|
|
robot_test_simple(doc, good, bad);
|
|
|
|
let good = vec!["/cyberworld/map/index.html"];
|
|
robot_test(doc, good, vec![], "cybermapper");
|
|
}
|
|
|
|
#[test]
|
|
fn test_robots_txt_3() {
|
|
let doc = "\n\
|
|
# go away\n\
|
|
User-agent: *\n\
|
|
Disallow: /\n\
|
|
";
|
|
let good = vec![];
|
|
let bad = vec!["/cyberworld/map/index.html","/","/tmp/"];
|
|
robot_test_simple(doc, good, bad);
|
|
}
|
|
|
|
#[test]
|
|
fn test_robots_txt_4() {
|
|
let doc = "\n\
|
|
User-agent: figtree\n\
|
|
Disallow: /tmp\n\
|
|
Disallow: /a%3cd.html\n\
|
|
Disallow: /a%2fb.html\n\
|
|
Disallow: /%7ejoe/index.html\n\
|
|
";
|
|
let good = vec![];
|
|
let bad = vec![
|
|
"/tmp", "/tmp.html", "/tmp/a.html", "/a%3cd.html", "/a%3Cd.html",
|
|
"/a%2fb.html", "/~joe/index.html",
|
|
];
|
|
robot_test(doc, good.clone(), bad.clone(), "figtree");
|
|
robot_test(doc, good, bad, "FigTree Robot libwww-perl/5.04");
|
|
}
|
|
|
|
#[test]
|
|
fn test_robots_txt_5() {
|
|
let doc = "\n\
|
|
User-agent: *\n\
|
|
Disallow: /tmp/\n\
|
|
Disallow: /a%3Cd.html\n\
|
|
Disallow: /a/b.html\n\
|
|
Disallow: /%7ejoe/index.html\n\
|
|
";
|
|
let good = vec!["/tmp"];
|
|
let bad = vec![
|
|
"/tmp/", "/tmp/a.html", "/a%3cd.html", "/a%3Cd.html",
|
|
"/a/b.html", "/%7Ejoe/index.html",
|
|
];
|
|
robot_test_simple(doc, good, bad);
|
|
}
|
|
|
|
#[test]
|
|
fn test_robots_txt_6() {
|
|
let doc = "\n\
|
|
User-Agent: *\n\
|
|
Disallow: /.\n\
|
|
";
|
|
let good = vec!["/foo.html"];
|
|
let bad = vec![];
|
|
robot_test_simple(doc, good, bad);
|
|
}
|
|
|
|
#[test]
|
|
fn test_robots_txt_7() {
|
|
let doc = "\n\
|
|
User-agent: Googlebot\n\
|
|
Allow: /folder1/myfile.html\n\
|
|
Disallow: /folder1/\n\
|
|
";
|
|
let good = vec!["/folder1/myfile.html"];
|
|
let bad = vec!["/folder1/anotherfile.html"];
|
|
robot_test(doc, good, bad, "Googlebot");
|
|
}
|
|
|
|
/// This file is incorrect because "Googlebot" is a substring of "Googlebot-Mobile"
|
|
#[test]
|
|
fn test_robots_txt_8() {
|
|
let doc = "\n\
|
|
User-agent: Googlebot\n\
|
|
Disallow: /\n\
|
|
\n\
|
|
User-agent: Googlebot-Mobile\n\
|
|
Allow: /\n\
|
|
";
|
|
let good = vec![];
|
|
let bad = vec!["/something.jpg"];
|
|
robot_test(doc, good.clone(), bad.clone(), "Googlebot");
|
|
robot_test(doc, good, bad, "Googlebot-Mobile");
|
|
}
|
|
|
|
#[test]
|
|
fn test_robots_txt_9() {
|
|
let doc = "\n\
|
|
User-agent: Googlebot-Mobile\n\
|
|
Allow: /\n\
|
|
\n\
|
|
User-agent: Googlebot\n\
|
|
Disallow: /\n\
|
|
";
|
|
let good = vec![];
|
|
let bad = vec!["/something.jpg"];
|
|
robot_test(doc, good.clone(), bad.clone(), "Googlebot");
|
|
robot_test(doc, bad, good, "Googlebot-Mobile");
|
|
}
|
|
|
|
#[test]
|
|
fn test_robots_txt_10() {
|
|
let doc = "\n\
|
|
User-agent: Googlebot\n\
|
|
Allow: /folder1/myfile.html\n\
|
|
Disallow: /folder1/\n\
|
|
";
|
|
let good = vec!["/folder1/myfile.html"];
|
|
let bad = vec!["/folder1/anotherfile.html"];
|
|
robot_test(doc, good, bad, "googlebot");
|
|
}
|
|
|
|
/// query string support
|
|
#[test]
|
|
fn test_robots_txt_11() {
|
|
let doc = "\n\
|
|
User-agent: *\n\
|
|
Disallow: /some/path?name=value\n\
|
|
";
|
|
let good = vec!["/some/path"];
|
|
let bad = vec!["/some/path?name=value"];
|
|
robot_test_simple(doc, good, bad);
|
|
}
|
|
|
|
/// obey first * entry
|
|
#[test]
|
|
fn test_robots_txt_12() {
|
|
let doc = "\n\
|
|
User-agent: *\n\
|
|
Disallow: /some/path\n\
|
|
\n\
|
|
User-agent: *\n\
|
|
Disallow: /another/path\n\
|
|
";
|
|
let good = vec!["/another/path"];
|
|
let bad = vec!["/some/path"];
|
|
robot_test_simple(doc, good, bad);
|
|
}
|
|
|
|
/// Empty query. Normalizing the url first.
|
|
#[test]
|
|
fn test_robots_txt_13() {
|
|
let doc = "\n\
|
|
User-agent: *\n\
|
|
Allow: /some/path?\n\
|
|
Disallow: /another/path?\n\
|
|
";
|
|
let good = vec!["/some/path?"];
|
|
let bad = vec!["/another/path?"];
|
|
robot_test_simple(doc, good, bad);
|
|
}
|
|
|
|
#[test]
|
|
fn test_robots_txt_read() {
|
|
let parser = RobotFileParser::new("http://www.python.org/robots.txt");
|
|
parser.read();
|
|
assert!(parser.can_fetch("*", "http://www.python.org/robots.txt"));
|
|
}
|
|
|
|
#[test]
|
|
fn test_robots_text_crawl_delay() {
|
|
let parser = RobotFileParser::new("http://www.python.org/robots.txt");
|
|
let doc = "User-agent: Yandex\n\
|
|
Crawl-delay: 2.35\n\
|
|
Disallow: /search/\n";
|
|
let lines: Vec<&str> = doc.split("\n").collect();
|
|
parser.parse(&lines);
|
|
assert_eq!(Duration::new(2,350 * 1000 * 1000), parser.get_crawl_delay("Yandex").unwrap());
|
|
}
|
|
|
|
#[test]
|
|
fn test_robots_text_sitemaps() {
|
|
let parser = RobotFileParser::new("http://www.python.org/robots.txt");
|
|
let doc = "User-agent: Yandex\n\
|
|
Sitemap: http://example.com/sitemap1.xml
|
|
Sitemap: http://example.com/sitemap2.xml
|
|
Sitemap: http://example.com/sitemap3.xml
|
|
Disallow: /search/\n";
|
|
let lines: Vec<&str> = doc.split("\n").collect();
|
|
parser.parse(&lines);
|
|
assert_eq!(
|
|
vec![
|
|
Url::parse("http://example.com/sitemap1.xml").unwrap(),
|
|
Url::parse("http://example.com/sitemap2.xml").unwrap(),
|
|
Url::parse("http://example.com/sitemap3.xml").unwrap()
|
|
],
|
|
parser.get_sitemaps("Yandex")
|
|
);
|
|
}
|