HW10 is completed
This commit is contained in:
parent
9d97b3e732
commit
956abaaeca
@ -30,6 +30,13 @@ GetDomainStat(r, "edu") // {"quinu": 1}
|
|||||||
- удалять имеющийся лишний код (кроме функции `GetDomainStat`);
|
- удалять имеющийся лишний код (кроме функции `GetDomainStat`);
|
||||||
- добавлять юнит-тесты.
|
- добавлять юнит-тесты.
|
||||||
|
|
||||||
|
**Обратите внимание на запуск TestGetDomainStat_Time_And_Memory**
|
||||||
|
```bash
|
||||||
|
go test -v -count=1 -timeout=30s -tags bench .
|
||||||
|
```
|
||||||
|
|
||||||
|
Здесь используется билд-тэг bench, чтобы отделить обычные тесты от тестов производительности.
|
||||||
|
|
||||||
### Критерии оценки
|
### Критерии оценки
|
||||||
- Пайплайн зелёный и нет попытки «обмануть» систему - 4 балла
|
- Пайплайн зелёный и нет попытки «обмануть» систему - 4 балла
|
||||||
- Добавлены юнит-тесты - до 3 баллов
|
- Добавлены юнит-тесты - до 3 баллов
|
||||||
|
@ -5,7 +5,6 @@ import (
|
|||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"regexp"
|
|
||||||
"strings"
|
"strings"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -29,38 +28,33 @@ func GetDomainStat(r io.Reader, domain string) (DomainStat, error) {
|
|||||||
return countDomains(u, domain)
|
return countDomains(u, domain)
|
||||||
}
|
}
|
||||||
|
|
||||||
type users [100000]User
|
type Users []User
|
||||||
|
|
||||||
func getUsers(r io.Reader) (result users, err error) {
|
func getUsers(r io.Reader) (Users, error) {
|
||||||
|
result := make([]User, 10000)
|
||||||
content, err := ioutil.ReadAll(r)
|
content, err := ioutil.ReadAll(r)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return result, err
|
||||||
}
|
}
|
||||||
|
|
||||||
lines := strings.Split(string(content), "\n")
|
lines := strings.Split(string(content), "\n")
|
||||||
for i, line := range lines {
|
for _, line := range lines {
|
||||||
var user User
|
var user User
|
||||||
if err = json.Unmarshal([]byte(line), &user); err != nil {
|
if err = json.Unmarshal([]byte(line), &user); err != nil {
|
||||||
return
|
return result, err
|
||||||
}
|
}
|
||||||
result[i] = user
|
result = append(result,user)
|
||||||
}
|
}
|
||||||
return
|
return result, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func countDomains(u users, domain string) (DomainStat, error) {
|
func countDomains(u Users, domain string) (DomainStat, error) {
|
||||||
result := make(DomainStat)
|
result := make(DomainStat)
|
||||||
|
i:=0
|
||||||
for _, user := range u {
|
for _, user := range u {
|
||||||
matched, err := regexp.Match("\\."+domain, []byte(user.Email))
|
if strings.Contains(user.Email,"."+domain) {
|
||||||
if err != nil {
|
result[strings.ToLower(strings.SplitN(user.Email, "@", 2)[1])]++
|
||||||
return nil, err
|
i++
|
||||||
}
|
|
||||||
|
|
||||||
if matched {
|
|
||||||
num := result[strings.ToLower(strings.SplitN(user.Email, "@", 2)[1])]
|
|
||||||
num++
|
|
||||||
result[strings.ToLower(strings.SplitN(user.Email, "@", 2)[1])] = num
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return result, nil
|
return result, nil
|
||||||
|
Loading…
x
Reference in New Issue
Block a user