use plotpy::{Plot, Surface};
use russell_lab::generate3d;
use std::fs::File;
use std::io::{BufRead, BufReader};
use std::path::Path;
const OUT_DIR: &str = "/tmp/plotpy/integ_tests";
#[test]
fn test_surface() -> Result<(), &'static str> {
let mut surface = Surface::new();
surface
.set_row_stride(1)
.set_col_stride(1)
.set_with_wireframe(true)
.set_colormap_name("Pastel1")
.set_with_colorbar(true)
.set_colorbar_label("temperature")
.set_number_format_cb("%.1f")
.set_line_color("#1862ab")
.set_line_style(":")
.set_line_width(0.75);
let n = 9;
let (x, y, z) = generate3d(-2.0, 2.0, -2.0, 2.0, n, n, |x, y| x * x + y * y);
surface.draw(&x, &y, &z);
let mut plot = Plot::new();
plot.add(&surface);
let path = Path::new(OUT_DIR).join("integ_surface.svg");
plot.save(&path)?;
let file = File::open(path).map_err(|_| "cannot open file")?;
let buffered = BufReader::new(file);
let lines_iter = buffered.lines();
assert!(lines_iter.count() > 1650);
Ok(())
}
#[test]
fn test_wireframe() -> Result<(), &'static str> {
let mut surface = Surface::new();
surface.set_with_surface(false).set_with_wireframe(true);
let n = 9;
let (x, y, z) = generate3d(-2.0, 2.0, -2.0, 2.0, n, n, |x, y| x * x + y * y);
surface.draw(&x, &y, &z);
let mut plot = Plot::new();
plot.add(&surface);
let path = Path::new(OUT_DIR).join("integ_wireframe.svg");
plot.save(&path)?;
let file = File::open(path).map_err(|_| "cannot open file")?;
let buffered = BufReader::new(file);
let lines_iter = buffered.lines();
assert!(lines_iter.count() > 890);
Ok(())
}