// use helix_tui::{
//     backend::TestBackend,
//     buffer::Buffer,
//     layout::Constraint,
//     style::{Color, Modifier, Style},
//     text::{Span, Spans},
//     widgets::{Block, Borders, Cell, Row, Table, TableState},
//     Terminal,
// };

// #[test]
// fn widgets_table_column_spacing_can_be_changed() {
//     let test_case = |column_spacing, expected| {
//         let backend = TestBackend::new(30, 10);
//         let mut terminal = Terminal::new(backend).unwrap();

//         terminal
//             .draw(|f| {
//                 let size = f.size();
//                 let table = Table::new(vec![
//                     Row::new(vec!["Row11", "Row12", "Row13"]),
//                     Row::new(vec!["Row21", "Row22", "Row23"]),
//                     Row::new(vec!["Row31", "Row32", "Row33"]),
//                     Row::new(vec!["Row41", "Row42", "Row43"]),
//                 ])
//                 .header(Row::new(vec!["Head1", "Head2", "Head3"]).bottom_margin(1))
//                 .block(Block::default().borders(Borders::ALL))
//                 .widths(&[
//                     Constraint::Length(5),
//                     Constraint::Length(5),
//                     Constraint::Length(5),
//                 ])
//                 .column_spacing(column_spacing);
//                 f.render_widget(table, size);
//             })
//             .unwrap();
//         terminal.backend().assert_buffer(&expected);
//     };

//     // no space between columns
//     test_case(
//         0,
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│Head1Head2Head3             │",
//             "│                            │",
//             "│Row11Row12Row13             │",
//             "│Row21Row22Row23             │",
//             "│Row31Row32Row33             │",
//             "│Row41Row42Row43             │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // one space between columns
//     test_case(
//         1,
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│Head1 Head2 Head3           │",
//             "│                            │",
//             "│Row11 Row12 Row13           │",
//             "│Row21 Row22 Row23           │",
//             "│Row31 Row32 Row33           │",
//             "│Row41 Row42 Row43           │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // enough space to just not hide the third column
//     test_case(
//         6,
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│Head1      Head2      Head3 │",
//             "│                            │",
//             "│Row11      Row12      Row13 │",
//             "│Row21      Row22      Row23 │",
//             "│Row31      Row32      Row33 │",
//             "│Row41      Row42      Row43 │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // enough space to hide part of the third column
//     test_case(
//         7,
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│Head1       Head2       Head│",
//             "│                            │",
//             "│Row11       Row12       Row1│",
//             "│Row21       Row22       Row2│",
//             "│Row31       Row32       Row3│",
//             "│Row41       Row42       Row4│",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );
// }

// #[test]
// fn widgets_table_columns_widths_can_use_fixed_length_constraints() {
//     let test_case = |widths, expected| {
//         let backend = TestBackend::new(30, 10);
//         let mut terminal = Terminal::new(backend).unwrap();

//         terminal
//             .draw(|f| {
//                 let size = f.size();
//                 let table = Table::new(vec![
//                     Row::new(vec!["Row11", "Row12", "Row13"]),
//                     Row::new(vec!["Row21", "Row22", "Row23"]),
//                     Row::new(vec!["Row31", "Row32", "Row33"]),
//                     Row::new(vec!["Row41", "Row42", "Row43"]),
//                 ])
//                 .header(Row::new(vec!["Head1", "Head2", "Head3"]).bottom_margin(1))
//                 .block(Block::default().borders(Borders::ALL))
//                 .widths(widths);
//                 f.render_widget(table, size);
//             })
//             .unwrap();
//         terminal.backend().assert_buffer(&expected);
//     };

//     // columns of zero width show nothing
//     test_case(
//         &[
//             Constraint::Length(0),
//             Constraint::Length(0),
//             Constraint::Length(0),
//         ],
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // columns of 1 width trim
//     test_case(
//         &[
//             Constraint::Length(1),
//             Constraint::Length(1),
//             Constraint::Length(1),
//         ],
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│H H H                       │",
//             "│                            │",
//             "│R R R                       │",
//             "│R R R                       │",
//             "│R R R                       │",
//             "│R R R                       │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // columns of large width just before pushing a column off
//     test_case(
//         &[
//             Constraint::Length(8),
//             Constraint::Length(8),
//             Constraint::Length(8),
//         ],
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│Head1    Head2    Head3     │",
//             "│                            │",
//             "│Row11    Row12    Row13     │",
//             "│Row21    Row22    Row23     │",
//             "│Row31    Row32    Row33     │",
//             "│Row41    Row42    Row43     │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );
// }

// #[test]
// fn widgets_table_columns_widths_can_use_percentage_constraints() {
//     let test_case = |widths, expected| {
//         let backend = TestBackend::new(30, 10);
//         let mut terminal = Terminal::new(backend).unwrap();

//         terminal
//             .draw(|f| {
//                 let size = f.size();
//                 let table = Table::new(vec![
//                     Row::new(vec!["Row11", "Row12", "Row13"]),
//                     Row::new(vec!["Row21", "Row22", "Row23"]),
//                     Row::new(vec!["Row31", "Row32", "Row33"]),
//                     Row::new(vec!["Row41", "Row42", "Row43"]),
//                 ])
//                 .header(Row::new(vec!["Head1", "Head2", "Head3"]).bottom_margin(1))
//                 .block(Block::default().borders(Borders::ALL))
//                 .widths(widths)
//                 .column_spacing(0);
//                 f.render_widget(table, size);
//             })
//             .unwrap();
//         terminal.backend().assert_buffer(&expected);
//     };

//     // columns of zero width show nothing
//     test_case(
//         &[
//             Constraint::Percentage(0),
//             Constraint::Percentage(0),
//             Constraint::Percentage(0),
//         ],
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // columns of not enough width trims the data
//     test_case(
//         &[
//             Constraint::Percentage(11),
//             Constraint::Percentage(11),
//             Constraint::Percentage(11),
//         ],
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│HeaHeaHea                   │",
//             "│                            │",
//             "│RowRowRow                   │",
//             "│RowRowRow                   │",
//             "│RowRowRow                   │",
//             "│RowRowRow                   │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // columns of large width just before pushing a column off
//     test_case(
//         &[
//             Constraint::Percentage(33),
//             Constraint::Percentage(33),
//             Constraint::Percentage(33),
//         ],
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│Head1    Head2    Head3     │",
//             "│                            │",
//             "│Row11    Row12    Row13     │",
//             "│Row21    Row22    Row23     │",
//             "│Row31    Row32    Row33     │",
//             "│Row41    Row42    Row43     │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // percentages summing to 100 should give equal widths
//     test_case(
//         &[Constraint::Percentage(50), Constraint::Percentage(50)],
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│Head1         Head2         │",
//             "│                            │",
//             "│Row11         Row12         │",
//             "│Row21         Row22         │",
//             "│Row31         Row32         │",
//             "│Row41         Row42         │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );
// }

// #[test]
// fn widgets_table_columns_widths_can_use_mixed_constraints() {
//     let test_case = |widths, expected| {
//         let backend = TestBackend::new(30, 10);
//         let mut terminal = Terminal::new(backend).unwrap();

//         terminal
//             .draw(|f| {
//                 let size = f.size();
//                 let table = Table::new(vec![
//                     Row::new(vec!["Row11", "Row12", "Row13"]),
//                     Row::new(vec!["Row21", "Row22", "Row23"]),
//                     Row::new(vec!["Row31", "Row32", "Row33"]),
//                     Row::new(vec!["Row41", "Row42", "Row43"]),
//                 ])
//                 .header(Row::new(vec!["Head1", "Head2", "Head3"]).bottom_margin(1))
//                 .block(Block::default().borders(Borders::ALL))
//                 .widths(widths);
//                 f.render_widget(table, size);
//             })
//             .unwrap();
//         terminal.backend().assert_buffer(&expected);
//     };

//     // columns of zero width show nothing
//     test_case(
//         &[
//             Constraint::Percentage(0),
//             Constraint::Length(0),
//             Constraint::Percentage(0),
//         ],
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // columns of not enough width trims the data
//     test_case(
//         &[
//             Constraint::Percentage(11),
//             Constraint::Length(20),
//             Constraint::Percentage(11),
//         ],
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│Hea Head2                Hea│",
//             "│                            │",
//             "│Row Row12                Row│",
//             "│Row Row22                Row│",
//             "│Row Row32                Row│",
//             "│Row Row42                Row│",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // columns of large width just before pushing a column off
//     test_case(
//         &[
//             Constraint::Percentage(33),
//             Constraint::Length(10),
//             Constraint::Percentage(33),
//         ],
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│Head1     Head2      Head3  │",
//             "│                            │",
//             "│Row11     Row12      Row13  │",
//             "│Row21     Row22      Row23  │",
//             "│Row31     Row32      Row33  │",
//             "│Row41     Row42      Row43  │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // columns of large size (>100% total) hide the last column
//     test_case(
//         &[
//             Constraint::Percentage(60),
//             Constraint::Length(10),
//             Constraint::Percentage(60),
//         ],
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│Head1            Head2      │",
//             "│                            │",
//             "│Row11            Row12      │",
//             "│Row21            Row22      │",
//             "│Row31            Row32      │",
//             "│Row41            Row42      │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );
// }

// #[test]
// fn widgets_table_columns_widths_can_use_ratio_constraints() {
//     let test_case = |widths, expected| {
//         let backend = TestBackend::new(30, 10);
//         let mut terminal = Terminal::new(backend).unwrap();

//         terminal
//             .draw(|f| {
//                 let size = f.size();
//                 let table = Table::new(vec![
//                     Row::new(vec!["Row11", "Row12", "Row13"]),
//                     Row::new(vec!["Row21", "Row22", "Row23"]),
//                     Row::new(vec!["Row31", "Row32", "Row33"]),
//                     Row::new(vec!["Row41", "Row42", "Row43"]),
//                 ])
//                 .header(Row::new(vec!["Head1", "Head2", "Head3"]).bottom_margin(1))
//                 .block(Block::default().borders(Borders::ALL))
//                 .widths(widths)
//                 .column_spacing(0);
//                 f.render_widget(table, size);
//             })
//             .unwrap();
//         terminal.backend().assert_buffer(&expected);
//     };

//     // columns of zero width show nothing
//     test_case(
//         &[
//             Constraint::Ratio(0, 1),
//             Constraint::Ratio(0, 1),
//             Constraint::Ratio(0, 1),
//         ],
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // columns of not enough width trims the data
//     test_case(
//         &[
//             Constraint::Ratio(1, 9),
//             Constraint::Ratio(1, 9),
//             Constraint::Ratio(1, 9),
//         ],
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│HeaHeaHea                   │",
//             "│                            │",
//             "│RowRowRow                   │",
//             "│RowRowRow                   │",
//             "│RowRowRow                   │",
//             "│RowRowRow                   │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // columns of large width just before pushing a column off
//     test_case(
//         &[
//             Constraint::Ratio(1, 3),
//             Constraint::Ratio(1, 3),
//             Constraint::Ratio(1, 3),
//         ],
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│Head1    Head2    Head3     │",
//             "│                            │",
//             "│Row11    Row12    Row13     │",
//             "│Row21    Row22    Row23     │",
//             "│Row31    Row32    Row33     │",
//             "│Row41    Row42    Row43     │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // percentages summing to 100 should give equal widths
//     test_case(
//         &[Constraint::Ratio(1, 2), Constraint::Ratio(1, 2)],
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│Head1         Head2         │",
//             "│                            │",
//             "│Row11         Row12         │",
//             "│Row21         Row22         │",
//             "│Row31         Row32         │",
//             "│Row41         Row42         │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );
// }

// #[test]
// fn widgets_table_can_have_rows_with_multi_lines() {
//     let test_case = |state: &mut TableState, expected: Buffer| {
//         let backend = TestBackend::new(30, 8);
//         let mut terminal = Terminal::new(backend).unwrap();
//         terminal
//             .draw(|f| {
//                 let size = f.size();
//                 let table = Table::new(vec![
//                     Row::new(vec!["Row11", "Row12", "Row13"]),
//                     Row::new(vec!["Row21", "Row22", "Row23"]).height(2),
//                     Row::new(vec!["Row31", "Row32", "Row33"]),
//                     Row::new(vec!["Row41", "Row42", "Row43"]).height(2),
//                 ])
//                 .header(Row::new(vec!["Head1", "Head2", "Head3"]).bottom_margin(1))
//                 .block(Block::default().borders(Borders::ALL))
//                 .highlight_symbol(">> ")
//                 .widths(&[
//                     Constraint::Length(5),
//                     Constraint::Length(5),
//                     Constraint::Length(5),
//                 ])
//                 .column_spacing(1);
//                 f.render_stateful_widget(table, size, state);
//             })
//             .unwrap();
//         terminal.backend().assert_buffer(&expected);
//     };

//     let mut state = TableState::default();
//     // no selection
//     test_case(
//         &mut state,
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│Head1 Head2 Head3           │",
//             "│                            │",
//             "│Row11 Row12 Row13           │",
//             "│Row21 Row22 Row23           │",
//             "│                            │",
//             "│Row31 Row32 Row33           │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // select first
//     state.select(Some(0));
//     test_case(
//         &mut state,
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│   Head1 Head2 Head3        │",
//             "│                            │",
//             "│>> Row11 Row12 Row13        │",
//             "│   Row21 Row22 Row23        │",
//             "│                            │",
//             "│   Row31 Row32 Row33        │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // select second (we don't show partially the 4th row)
//     state.select(Some(1));
//     test_case(
//         &mut state,
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│   Head1 Head2 Head3        │",
//             "│                            │",
//             "│   Row11 Row12 Row13        │",
//             "│>> Row21 Row22 Row23        │",
//             "│                            │",
//             "│   Row31 Row32 Row33        │",
//             "└────────────────────────────┘",
//         ]),
//     );

//     // select 4th (we don't show partially the 1st row)
//     state.select(Some(3));
//     test_case(
//         &mut state,
//         Buffer::with_lines(vec![
//             "┌────────────────────────────┐",
//             "│   Head1 Head2 Head3        │",
//             "│                            │",
//             "│   Row31 Row32 Row33        │",
//             "│>> Row41 Row42 Row43        │",
//             "│                            │",
//             "│                            │",
//             "└────────────────────────────┘",
//         ]),
//     );
// }

// #[test]
// fn widgets_table_can_have_elements_styled_individually() {
//     let backend = TestBackend::new(30, 4);
//     let mut terminal = Terminal::new(backend).unwrap();
//     let mut state = TableState::default();
//     state.select(Some(0));
//     terminal
//         .draw(|f| {
//             let size = f.size();
//             let table = Table::new(vec![
//                 Row::new(vec!["Row11", "Row12", "Row13"]).style(Style::default().fg(Color::Green)),
//                 Row::new(vec![
//                     Cell::from("Row21"),
//                     Cell::from("Row22").style(Style::default().fg(Color::Yellow)),
//                     Cell::from(Spans::from(vec![
//                         Span::raw("Row"),
//                         Span::styled("23", Style::default().fg(Color::Blue)),
//                     ]))
//                     .style(Style::default().fg(Color::Red)),
//                 ])
//                 .style(Style::default().fg(Color::LightGreen)),
//             ])
//             .header(Row::new(vec!["Head1", "Head2", "Head3"]).bottom_margin(1))
//             .block(Block::default().borders(Borders::LEFT | Borders::RIGHT))
//             .highlight_symbol(">> ")
//             .highlight_style(Style::default().add_modifier(Modifier::BOLD))
//             .widths(&[
//                 Constraint::Length(6),
//                 Constraint::Length(6),
//                 Constraint::Length(6),
//             ])
//             .column_spacing(1);
//             f.render_stateful_widget(table, size, &mut state);
//         })
//         .unwrap();

//     let mut expected = Buffer::with_lines(vec![
//         "│   Head1  Head2  Head3      │",
//         "│                            │",
//         "│>> Row11  Row12  Row13      │",
//         "│   Row21  Row22  Row23      │",
//     ]);
//     // First row = row color + highlight style
//     for col in 1..=28 {
//         expected.get_mut(col, 2).set_style(
//             Style::default()
//                 .fg(Color::Green)
//                 .add_modifier(Modifier::BOLD),
//         );
//     }
//     // Second row:
//     // 1. row color
//     for col in 1..=28 {
//         expected
//             .get_mut(col, 3)
//             .set_style(Style::default().fg(Color::LightGreen));
//     }
//     // 2. cell color
//     for col in 11..=16 {
//         expected
//             .get_mut(col, 3)
//             .set_style(Style::default().fg(Color::Yellow));
//     }
//     for col in 18..=23 {
//         expected
//             .get_mut(col, 3)
//             .set_style(Style::default().fg(Color::Red));
//     }
//     // 3. text color
//     for col in 21..=22 {
//         expected
//             .get_mut(col, 3)
//             .set_style(Style::default().fg(Color::Blue));
//     }
//     terminal.backend().assert_buffer(&expected);
// }

// #[test]
// fn widgets_table_should_render_even_if_empty() {
//     let backend = TestBackend::new(30, 4);
//     let mut terminal = Terminal::new(backend).unwrap();
//     terminal
//         .draw(|f| {
//             let size = f.size();
//             let table = Table::new(vec![])
//                 .header(Row::new(vec!["Head1", "Head2", "Head3"]))
//                 .block(Block::default().borders(Borders::LEFT | Borders::RIGHT))
//                 .widths(&[
//                     Constraint::Length(6),
//                     Constraint::Length(6),
//                     Constraint::Length(6),
//                 ])
//                 .column_spacing(1);
//             f.render_widget(table, size);
//         })
//         .unwrap();

//     let expected = Buffer::with_lines(vec![
//         "│Head1  Head2  Head3         │",
//         "│                            │",
//         "│                            │",
//         "│                            │",
//     ]);

//     terminal.backend().assert_buffer(&expected);
// }