Skip to content
This repository has been archived by the owner on May 10, 2024. It is now read-only.

Commit

Permalink
Fix #3022: Update Yandex search engine.
Browse files Browse the repository at this point in the history
  • Loading branch information
iccub committed Nov 18, 2020
1 parent 6881727 commit 6d2237b
Show file tree
Hide file tree
Showing 5 changed files with 31 additions and 121 deletions.
21 changes: 0 additions & 21 deletions Client/Assets/SearchPlugins/yandex-ru.xml

This file was deleted.

22 changes: 0 additions & 22 deletions Client/Assets/SearchPlugins/yandex-tr.xml

This file was deleted.

12 changes: 5 additions & 7 deletions Client/Assets/SearchPlugins/yandex.xml
Original file line number Diff line number Diff line change
Expand Up @@ -6,16 +6,14 @@
<ShortName>Яндекс</ShortName>
<InputEncoding>UTF-8</InputEncoding>
<Image width="16" height="16"></Image>
<Url type="application/x-suggestions+json" method="GET" template="https://suggest.yandex.net/suggest-ff.cgi">
<Url type="application/x-suggestions+json" method="GET" template="https://suggest.yandex.ru/suggest-ff.cgi">
<Param name="part" value="{searchTerms}"/>
<!-- Despite name, this param applies to both desktop and mobile clients. -->
<Param name="srv" value="brave_desktop"/>
</Url>
<Url type="text/html" method="GET" template="https://yandex.kz/yandsearch">
<Param name="clid" value="2186727"/>
<Param name="text" value="{searchTerms}"/>
</Url>
<Url type="application/x-moz-tabletsearch" method="GET" template="https://yandex.kz/yandsearch">
<Param name="clid" value="2186733"/>
<Url type="text/html" method="GET" template="https://yandex.ru/search">
<Param name="text" value="{searchTerms}"/>
<Param name="clid" value="2423859"/>
</Url>
<SearchForm>https://www.yandex.kz/</SearchForm>
</SearchPlugin>
33 changes: 6 additions & 27 deletions Client/Frontend/Browser/Search/InitialSearchEngines.swift
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ class InitialSearchEngines {

static let ddgDefaultRegions = ["DE", "AU", "NZ", "IE"]
static let qwantDefaultRegions = ["FR"]
static let yandexDefaultRegions = ["BY", "KZ", "RU", "TR"]
static let yandexDefaultRegions = ["AM", "AZ", "BY", "KG", "KZ", "MD", "RU", "TJ", "TM", "TZ"]
static let yahooEligibleRegions =
["GB", "US", "AR", "AT", "AU", "BR", "CA", "CH", "CL", "CO", "DE", "DK", "ES", "FI", "FR", "HK",
"ID", "IE", "IN", "IT", "MX", "MY", "NL", "NO", "NZ", "PE", "PH", "SE", "SG", "TH", "TW", "VE", "VN"]
Expand Down Expand Up @@ -99,35 +99,10 @@ class InitialSearchEngines {
// MARK: - Locale overrides

private func languageOverrides() {
guard let language = locale.languageCode, let region = locale.regionCode else { return }
guard let language = locale.languageCode else { return }
if language == "ja" {
replaceOrInsert(engineId: .yahoo, customId: "yahoo-jp")
}

if language == "ru" {
replaceOrInsert(engineId: .yandex, customId: "yandex-ru")

if Self.yandexDefaultRegions.contains(region) {
defaultSearchEngine = .yandex
}
}

if language == "kk" {
engines.append(.init(id: .yandex))

if Self.yandexDefaultRegions.contains(region) {
defaultSearchEngine = .yandex
}
}

if language == "tr" {
replaceOrInsert(engineId: .yandex, customId: "yandex-tr")

if Self.yandexDefaultRegions.contains(region) {
defaultSearchEngine = .yandex
}
}

}

private func regionOverrides() {
Expand All @@ -140,6 +115,10 @@ class InitialSearchEngines {
if Self.qwantDefaultRegions.contains(region) {
defaultSearchEngine = .qwant
}

if Self.yandexDefaultRegions.contains(region) {
defaultSearchEngine = .yandex
}
}

private func priorityOverrides() {
Expand Down
64 changes: 20 additions & 44 deletions ClientTests/InitialSearchEnginesTests.swift
Original file line number Diff line number Diff line change
Expand Up @@ -51,50 +51,11 @@ class InitialSearchEnginesTests: XCTestCase {
}
}

func testYandexLocales() throws {

for language in ["ru", "kk", "tr"] {
for region in InitialSearchEngines.yandexDefaultRegions {
let localeSE = SE(locale: Locale(identifier: "\(language)_\(region)"))
let engines = localeSE.engines.map { $0.id }

XCTAssertEqual(engines, [.yandex,
.google,
.bing,
.duckduckgo,
.qwant,
.startpage])

XCTAssertEqual(localeSE.defaultSearchEngine, .yandex)

// Check for language specific search engines
if language == "ru" {
XCTAssertNotNil(localeSE.engines.first(where: { $0.customId == "yandex-ru" }))
}

if language == "tr" {
XCTAssertNotNil(localeSE.engines.first(where: { $0.customId == "yandex-tr" }))
}

if language == "kk" {
XCTAssertNil(localeSE.engines.first(where: { $0.id == .yandex })?.customId)
}
}

// non matching region
for region in ["XX", "PL"] {
let localeSE = SE(locale: Locale(identifier: "\(language)_\(region)"))
let engines = localeSE.engines.map { $0.id }

XCTAssertEqual(engines, [.google,
.bing,
.duckduckgo,
.qwant,
.startpage,
.yandex])

XCTAssertEqual(localeSE.defaultSearchEngine, .google)
}
func testYandexRegions() throws {

for region in InitialSearchEngines.yandexDefaultRegions {
let localeSE = SE(locale: Locale(identifier: "ru_\(region)"))
XCTAssertEqual(localeSE.defaultSearchEngine, .yandex)
}
}

Expand Down Expand Up @@ -189,4 +150,19 @@ class InitialSearchEnginesTests: XCTestCase {
XCTAssertEqual(unknownLocaleSE.defaultSearchEngine, .google)
XCTAssertNil(unknownLocaleSE.priorityEngine)
}

func testRuRu() throws {
let russianLocale = SE(locale: Locale(identifier: "ru_RU"))
let engines = russianLocale.engines.map { $0.id }

XCTAssertEqual(engines, [.yandex,
.google,
.bing,
.duckduckgo,
.qwant,
.startpage])

XCTAssertEqual(russianLocale.defaultSearchEngine, .yandex)
XCTAssertNil(russianLocale.priorityEngine)
}
}

0 comments on commit 6d2237b

Please sign in to comment.