blob: c19d6e62a0cd09841c7ce39828cbbaf3706175e4 [file] [log] [blame]
// Copyright (C) 2024 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
import {createFakeTraceImpl} from '../../../../common/fake_trace_impl';
import {tableColumnId} from './column';
import {SqlTableState} from './state';
import {SqlTableDescription} from './table_description';
import {
ArgSetColumnSet,
StandardColumn,
TimestampColumn,
} from './well_known_columns';
const idColumn = new StandardColumn('id');
const nameColumn = new StandardColumn('name', {title: 'Name'});
const tsColumn = new TimestampColumn('ts', {
title: 'Timestamp',
startsHidden: true,
});
const table: SqlTableDescription = {
name: 'table',
displayName: 'Table',
columns: [idColumn, nameColumn, tsColumn, new ArgSetColumnSet('arg_set_id')],
};
test('sqlTableState: columnManupulation', () => {
const trace = createFakeTraceImpl({allowQueries: true});
const state = new SqlTableState(trace, table);
// The initial set of columns should include "id" and "name",
// but not "ts" (as it is marked as startsHidden) and not "arg_set_id"
// (as it is a special column).
expect(state.getSelectedColumns().map((c) => tableColumnId(c))).toEqual([
'id',
'name',
]);
state.addColumn(tsColumn, 0);
expect(state.getSelectedColumns().map((c) => tableColumnId(c))).toEqual([
'id',
'ts',
'name',
]);
state.hideColumnAtIndex(0);
expect(state.getSelectedColumns().map((c) => tableColumnId(c))).toEqual([
'ts',
'name',
]);
});
test('sqlTableState: sortedColumns', () => {
const trace = createFakeTraceImpl({allowQueries: true});
const state = new SqlTableState(trace, table);
// Verify that we have two columns: "id" and "name" and
// save references to them.
expect(state.getSelectedColumns().map((c) => tableColumnId(c))).toEqual([
'id',
'name',
]);
// Sort by name column and verify that it is sorted by.
state.sortBy({
column: nameColumn.primaryColumn(),
direction: 'ASC',
});
expect(state.isSortedBy(idColumn)).toBe(undefined);
expect(state.isSortedBy(nameColumn)).toBe('ASC');
// Sort by the same column in the opposite direction.
state.sortBy({
column: nameColumn.primaryColumn(),
direction: 'DESC',
});
expect(state.isSortedBy(idColumn)).toBe(undefined);
expect(state.isSortedBy(nameColumn)).toBe('DESC');
// Sort by the id column.
state.sortBy({
column: idColumn.primaryColumn(),
direction: 'ASC',
});
expect(state.isSortedBy(idColumn)).toBe('ASC');
expect(state.isSortedBy(nameColumn)).toBe(undefined);
// When the column is hidden, it should no longer be sorted by
// and we should fall back to the previously sorted by column.
state.hideColumnAtIndex(0);
expect(state.isSortedBy(nameColumn)).toBe('DESC');
// Remove the sorting and verify that we are no sorted by.
state.unsort();
expect(state.isSortedBy(nameColumn)).toBe(undefined);
});
// Clean up repeated whitespaces to allow for easier testing.
function normalize(s: string): string {
return s.replace(/\s+/g, ' ').trim();
}
test('sqlTableState: sqlStatement', () => {
const trace = createFakeTraceImpl({allowQueries: true});
const state = new SqlTableState(trace, table);
// Check the generated SQL statement.
expect(normalize(state.getCurrentRequest().query)).toBe(
'SELECT table_0.id AS id, table_0.name AS name FROM table AS table_0 LIMIT 101 OFFSET 0',
);
});