| /** |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you 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 getDashboardUrl from 'src/dashboard/util/getDashboardUrl'; |
| import { DASHBOARD_FILTER_SCOPE_GLOBAL } from 'src/dashboard/reducers/dashboardFilters'; |
| import { DashboardStandaloneMode } from 'src/dashboard/util/constants'; |
| |
| describe('getChartIdsFromLayout', () => { |
| const filters = { |
| '35_key': { |
| values: ['value'], |
| scope: DASHBOARD_FILTER_SCOPE_GLOBAL, |
| }, |
| }; |
| |
| const globalLocation = window.location; |
| afterEach(() => { |
| window.location = globalLocation; |
| }); |
| |
| it('should encode filters', () => { |
| const url = getDashboardUrl({ pathname: 'path', filters }); |
| expect(url).toBe( |
| 'path?preselect_filters=%7B%2235%22%3A%7B%22key%22%3A%5B%22value%22%5D%7D%7D', |
| ); |
| }); |
| |
| it('should encode filters with hash', () => { |
| const urlWithHash = getDashboardUrl({ |
| pathname: 'path', |
| filters, |
| hash: 'iamhashtag', |
| }); |
| expect(urlWithHash).toBe( |
| 'path?preselect_filters=%7B%2235%22%3A%7B%22key%22%3A%5B%22value%22%5D%7D%7D#iamhashtag', |
| ); |
| }); |
| |
| it('should encode filters with standalone', () => { |
| const urlWithStandalone = getDashboardUrl({ |
| pathname: 'path', |
| filters, |
| standalone: DashboardStandaloneMode.HideNav, |
| }); |
| expect(urlWithStandalone).toBe( |
| `path?preselect_filters=%7B%2235%22%3A%7B%22key%22%3A%5B%22value%22%5D%7D%7D&standalone=${DashboardStandaloneMode.HideNav}`, |
| ); |
| }); |
| |
| it('should encode filters with missing standalone', () => { |
| const urlWithStandalone = getDashboardUrl({ |
| pathname: 'path', |
| filters, |
| standalone: null, |
| }); |
| expect(urlWithStandalone).toBe( |
| 'path?preselect_filters=%7B%2235%22%3A%7B%22key%22%3A%5B%22value%22%5D%7D%7D', |
| ); |
| }); |
| |
| it('should encode filters with missing filters', () => { |
| const urlWithStandalone = getDashboardUrl({ |
| pathname: 'path', |
| filters: undefined, |
| standalone: DashboardStandaloneMode.HideNav, |
| }); |
| expect(urlWithStandalone).toBe( |
| `path?standalone=${DashboardStandaloneMode.HideNav}`, |
| ); |
| }); |
| |
| it('should preserve unknown filters', () => { |
| const windowSpy = jest.spyOn(window, 'window', 'get'); |
| windowSpy.mockImplementation(() => ({ |
| location: { |
| origin: 'https://localhost', |
| search: '?unknown_param=value', |
| }, |
| })); |
| const urlWithStandalone = getDashboardUrl({ |
| pathname: 'path', |
| standalone: DashboardStandaloneMode.HideNav, |
| }); |
| expect(urlWithStandalone).toBe( |
| `path?unknown_param=value&standalone=${DashboardStandaloneMode.HideNav}`, |
| ); |
| windowSpy.mockRestore(); |
| }); |
| |
| it('should process native filters key', () => { |
| const windowSpy = jest.spyOn(window, 'window', 'get'); |
| windowSpy.mockImplementation(() => ({ |
| location: { |
| origin: 'https://localhost', |
| search: |
| '?preselect_filters=%7B%7D&native_filters_key=024380498jdkjf-2094838', |
| }, |
| })); |
| |
| const urlWithNativeFilters = getDashboardUrl({ |
| pathname: 'path', |
| }); |
| expect(urlWithNativeFilters).toBe( |
| 'path?preselect_filters=%7B%7D&native_filters_key=024380498jdkjf-2094838', |
| ); |
| windowSpy.mockRestore(); |
| }); |
| }); |