mirror of
https://github.com/denoland/deno.git
synced 2025-01-21 13:00:36 -05:00
tests
This commit is contained in:
parent
ae87b37215
commit
03ed40abad
5 changed files with 59 additions and 35 deletions
|
@ -11,7 +11,6 @@ use deno_core::anyhow::Context;
|
||||||
use deno_core::error::AnyError;
|
use deno_core::error::AnyError;
|
||||||
use deno_graph::ModuleGraph;
|
use deno_graph::ModuleGraph;
|
||||||
use deno_lint::diagnostic::LintDiagnostic;
|
use deno_lint::diagnostic::LintDiagnostic;
|
||||||
use deno_lint::diagnostic::LintDiagnosticDetails;
|
|
||||||
use deno_lint::linter::LintConfig as DenoLintConfig;
|
use deno_lint::linter::LintConfig as DenoLintConfig;
|
||||||
use deno_lint::linter::LintFileOptions;
|
use deno_lint::linter::LintFileOptions;
|
||||||
use deno_lint::linter::Linter as DenoLintLinter;
|
use deno_lint::linter::Linter as DenoLintLinter;
|
||||||
|
@ -33,7 +32,7 @@ pub enum LintResult {
|
||||||
},
|
},
|
||||||
/// File was not parsed and linted because, eg. it might have
|
/// File was not parsed and linted because, eg. it might have
|
||||||
/// been a minified file.
|
/// been a minified file.
|
||||||
Skipped { diagnostic: Box<LintDiagnostic> },
|
Skipped { reason: String },
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct CliLinterOptions {
|
pub struct CliLinterOptions {
|
||||||
|
@ -111,22 +110,10 @@ impl CliLinter {
|
||||||
) -> Result<LintResult, AnyError> {
|
) -> Result<LintResult, AnyError> {
|
||||||
let specifier = specifier_from_file_path(file_path)?;
|
let specifier = specifier_from_file_path(file_path)?;
|
||||||
|
|
||||||
let metrics = minified_file::analyze_content(&source_code);
|
if minified_file::is_likely_minified(&source_code) {
|
||||||
if metrics.is_likely_minified() {
|
return Ok(LintResult::Skipped {
|
||||||
let details = LintDiagnosticDetails {
|
reason: "The file is minified".to_string(),
|
||||||
message: "File was not linted, because it's minified".to_string(),
|
|
||||||
code: "".to_string(),
|
|
||||||
hint: None,
|
|
||||||
fixes: vec![],
|
|
||||||
custom_docs_url: None,
|
|
||||||
info: vec![],
|
|
||||||
};
|
|
||||||
let diagnostic = Box::new(LintDiagnostic {
|
|
||||||
specifier,
|
|
||||||
range: None,
|
|
||||||
details,
|
|
||||||
});
|
});
|
||||||
return Ok(LintResult::Skipped { diagnostic });
|
|
||||||
}
|
}
|
||||||
|
|
||||||
let media_type = if let Some(ext) = ext {
|
let media_type = if let Some(ext) = ext {
|
||||||
|
|
|
@ -19,7 +19,8 @@ impl FileMetrics {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn analyze_content(content: &str) -> FileMetrics {
|
/// Analyze the content and tell if the file is most likely a minified file or not.
|
||||||
|
pub fn is_likely_minified(content: &str) -> bool {
|
||||||
const LONG_LINE_LEN: usize = 250;
|
const LONG_LINE_LEN: usize = 250;
|
||||||
let mut total_lines = 0;
|
let mut total_lines = 0;
|
||||||
let mut long_lines_count = 0;
|
let mut long_lines_count = 0;
|
||||||
|
@ -28,6 +29,12 @@ pub fn analyze_content(content: &str) -> FileMetrics {
|
||||||
let mut has_license = false;
|
let mut has_license = false;
|
||||||
let mut in_multiline_comment = false;
|
let mut in_multiline_comment = false;
|
||||||
|
|
||||||
|
// If total len of a file is shorter than the "long line" length, don't bother analyzing
|
||||||
|
// and consider non-minified.
|
||||||
|
if content.len() < LONG_LINE_LEN {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// Preallocate a line buffer to avoid per-line allocations
|
// Preallocate a line buffer to avoid per-line allocations
|
||||||
let mut line_buffer = String::with_capacity(1024);
|
let mut line_buffer = String::with_capacity(1024);
|
||||||
|
|
||||||
|
@ -93,12 +100,14 @@ pub fn analyze_content(content: &str) -> FileMetrics {
|
||||||
0.0
|
0.0
|
||||||
};
|
};
|
||||||
|
|
||||||
FileMetrics {
|
let metrics = FileMetrics {
|
||||||
long_lines_count,
|
long_lines_count,
|
||||||
total_lines,
|
total_lines,
|
||||||
whitespace_ratio,
|
whitespace_ratio,
|
||||||
has_license_comment: has_license,
|
has_license_comment: has_license,
|
||||||
}
|
};
|
||||||
|
|
||||||
|
metrics.is_likely_minified()
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
|
@ -119,31 +128,32 @@ const x = 42;
|
||||||
/* Multi-line
|
/* Multi-line
|
||||||
comment */
|
comment */
|
||||||
"#;
|
"#;
|
||||||
let metrics = analyze_content(content);
|
assert!(!is_likely_minified(content));
|
||||||
assert!(!metrics.is_likely_minified());
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn empty_file() {
|
||||||
|
assert!(!is_likely_minified(""));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_minified_file_col_length() {
|
fn test_minified_file_col_length() {
|
||||||
let content =
|
let content =
|
||||||
"const LOREM_IPSUM = `Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.`";
|
"const LOREM_IPSUM = `Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.`";
|
||||||
let metrics = analyze_content(content);
|
assert!(is_likely_minified(content));
|
||||||
assert!(metrics.is_likely_minified());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_minified_js() {
|
fn test_minified_js() {
|
||||||
let content = "function hello(){console.log(\"Hello, world!\")}const x=42;function veryLongFunction(){return\"This is a very long line that exceeds 250 characters and contains lots of code and stuff and more code and even more stuff until we definitely exceed the limit we set for considering a line to be very long in our minification detection algorithm\"}";
|
let content = "function hello(){console.log(\"Hello, world!\")}const x=42;function veryLongFunction(){return\"This is a very long line that exceeds 250 characters and contains lots of code and stuff and more code and even more stuff until we definitely exceed the limit we set for considering a line to be very long in our minification detection algorithm\"}";
|
||||||
let metrics = analyze_content(content);
|
assert!(is_likely_minified(content));
|
||||||
assert!(metrics.is_likely_minified());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_minified_file_whitespace() {
|
fn test_minified_file_whitespace() {
|
||||||
let content =
|
let content =
|
||||||
"function f(a,b){return a.concat(b)}var x=function(n){return n+1};";
|
"function f(a,b){return a.concat(b)}var x=function(n){return n+1};";
|
||||||
let metrics = analyze_content(content);
|
assert!(!is_likely_minified(content));
|
||||||
assert!(!metrics.is_likely_minified());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -153,8 +163,7 @@ const x = 42;
|
||||||
* Licensed under MIT License
|
* Licensed under MIT License
|
||||||
*/
|
*/
|
||||||
"#;
|
"#;
|
||||||
let metrics = analyze_content(content);
|
assert!(!is_likely_minified(content));
|
||||||
assert!(!metrics.is_likely_minified());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
|
@ -167,7 +176,6 @@ function concatenateArrays(array1, array2) {
|
||||||
const incrementNumber = function(number) {
|
const incrementNumber = function(number) {
|
||||||
return number + 1;
|
return number + 1;
|
||||||
};"#;
|
};"#;
|
||||||
let metrics = analyze_content(content);
|
assert!(!is_likely_minified(content));
|
||||||
assert!(!metrics.is_likely_minified());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -552,8 +552,8 @@ fn handle_lint_result(
|
||||||
}
|
}
|
||||||
diagnostics.is_empty()
|
diagnostics.is_empty()
|
||||||
}
|
}
|
||||||
LintResult::Skipped { diagnostic } => {
|
LintResult::Skipped { reason } => {
|
||||||
reporter.visit_diagnostic(&diagnostic);
|
reporter.visit_skipped(file_path, &reason);
|
||||||
true
|
true
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -569,3 +569,9 @@ struct LintError {
|
||||||
file_path: String,
|
file_path: String,
|
||||||
message: String,
|
message: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Serialize)]
|
||||||
|
struct LintSkipped {
|
||||||
|
file_path: String,
|
||||||
|
message: String,
|
||||||
|
}
|
||||||
|
|
|
@ -11,6 +11,7 @@ use serde::Serialize;
|
||||||
use crate::args::LintReporterKind;
|
use crate::args::LintReporterKind;
|
||||||
|
|
||||||
use super::LintError;
|
use super::LintError;
|
||||||
|
use super::LintSkipped;
|
||||||
|
|
||||||
const JSON_SCHEMA_VERSION: u8 = 1;
|
const JSON_SCHEMA_VERSION: u8 = 1;
|
||||||
|
|
||||||
|
@ -24,6 +25,7 @@ pub fn create_reporter(kind: LintReporterKind) -> Box<dyn LintReporter + Send> {
|
||||||
|
|
||||||
pub trait LintReporter {
|
pub trait LintReporter {
|
||||||
fn visit_diagnostic(&mut self, d: &LintDiagnostic);
|
fn visit_diagnostic(&mut self, d: &LintDiagnostic);
|
||||||
|
fn visit_skipped(&mut self, file_path: &str, reason: &str);
|
||||||
fn visit_error(&mut self, file_path: &str, err: &AnyError);
|
fn visit_error(&mut self, file_path: &str, err: &AnyError);
|
||||||
fn close(&mut self, check_count: usize);
|
fn close(&mut self, check_count: usize);
|
||||||
}
|
}
|
||||||
|
@ -52,6 +54,11 @@ impl LintReporter for PrettyLintReporter {
|
||||||
log::error!("{}\n", d.display());
|
log::error!("{}\n", d.display());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn visit_skipped(&mut self, file_path: &str, reason: &str) {
|
||||||
|
log::info!("File was skipped: {file_path}");
|
||||||
|
log::info!(" {reason}");
|
||||||
|
}
|
||||||
|
|
||||||
fn visit_error(&mut self, file_path: &str, err: &AnyError) {
|
fn visit_error(&mut self, file_path: &str, err: &AnyError) {
|
||||||
log::error!("Error linting: {file_path}");
|
log::error!("Error linting: {file_path}");
|
||||||
log::error!(" {err}");
|
log::error!(" {err}");
|
||||||
|
@ -113,6 +120,11 @@ impl LintReporter for CompactLintReporter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn visit_skipped(&mut self, file_path: &str, reason: &str) {
|
||||||
|
log::info!("File was skipped: {file_path}");
|
||||||
|
log::info!(" {reason}");
|
||||||
|
}
|
||||||
|
|
||||||
fn visit_error(&mut self, file_path: &str, err: &AnyError) {
|
fn visit_error(&mut self, file_path: &str, err: &AnyError) {
|
||||||
log::error!("Error linting: {file_path}");
|
log::error!("Error linting: {file_path}");
|
||||||
log::error!(" {err}");
|
log::error!(" {err}");
|
||||||
|
@ -174,6 +186,7 @@ struct JsonLintDiagnostic {
|
||||||
struct JsonLintReporter {
|
struct JsonLintReporter {
|
||||||
version: u8,
|
version: u8,
|
||||||
diagnostics: Vec<JsonLintDiagnostic>,
|
diagnostics: Vec<JsonLintDiagnostic>,
|
||||||
|
skipped: Vec<LintSkipped>,
|
||||||
errors: Vec<LintError>,
|
errors: Vec<LintError>,
|
||||||
checked_files: Vec<String>,
|
checked_files: Vec<String>,
|
||||||
}
|
}
|
||||||
|
@ -183,6 +196,7 @@ impl JsonLintReporter {
|
||||||
JsonLintReporter {
|
JsonLintReporter {
|
||||||
version: JSON_SCHEMA_VERSION,
|
version: JSON_SCHEMA_VERSION,
|
||||||
diagnostics: Vec::new(),
|
diagnostics: Vec::new(),
|
||||||
|
skipped: Vec::new(),
|
||||||
errors: Vec::new(),
|
errors: Vec::new(),
|
||||||
checked_files: Vec::new(),
|
checked_files: Vec::new(),
|
||||||
}
|
}
|
||||||
|
@ -224,6 +238,13 @@ impl LintReporter for JsonLintReporter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn visit_skipped(&mut self, file_path: &str, reason: &str) {
|
||||||
|
self.skipped.push(LintSkipped {
|
||||||
|
file_path: file_path.to_string(),
|
||||||
|
message: reason.to_string(),
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
fn visit_error(&mut self, file_path: &str, err: &AnyError) {
|
fn visit_error(&mut self, file_path: &str, err: &AnyError) {
|
||||||
self.errors.push(LintError {
|
self.errors.push(LintError {
|
||||||
file_path: file_path.to_string(),
|
file_path: file_path.to_string(),
|
||||||
|
|
|
@ -1 +1,3 @@
|
||||||
asdfasdf
|
File was skipped: [WILDCARD]minified.js
|
||||||
|
The file is minified
|
||||||
|
Checked 1 file
|
||||||
|
|
Loading…
Add table
Reference in a new issue