Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

일부 문제 복제(clone) 오류 #38

Closed
tuna1210 opened this issue Feb 3, 2018 · 2 comments
Closed

일부 문제 복제(clone) 오류 #38

tuna1210 opened this issue Feb 3, 2018 · 2 comments

Comments

@tuna1210
Copy link

tuna1210 commented Feb 3, 2018

SIGSEGV: invalid_state
corrupt page /problem/darksoul-3-goinmul/clone
site: fatal signal: Segmentation fault
site died (signal 500, exit -11)

panic: go back
Traceback (most recent call last):
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/core/handlers/exception.py", line 41, in inner
    response = get_response(request)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/core/handlers/base.py", line 187, in _get_response
    response = self.process_exception_by_middleware(e, request)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/core/handlers/base.py", line 185, in _get_response
    response = wrapped_callback(request, *callback_args, **callback_kwargs)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/views/decorators/http.py", line 40, in inner
    return func(request, *args, **kwargs)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/contrib/auth/decorators.py", line 23, in _wrapped_view
    return view_func(request, *args, **kwargs)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/contrib/auth/decorators.py", line 23, in _wrapped_view
    return view_func(request, *args, **kwargs)
  File "/home/litmus/site/judge/views/problem.py", line 627, in clone_problem
    problem.save()
  File "/home/litmus/site/judge/models/problem.py", line 286, in save
    super(Problem, self).save(*args, **kwargs)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/db/models/base.py", line 808, in save
    force_update=force_update, update_fields=update_fields)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/db/models/base.py", line 838, in save_base
    updated = self._save_table(raw, cls, force_insert, force_update, using, update_fields)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/db/models/base.py", line 924, in _save_table
    result = self._do_insert(cls._base_manager, using, fields, update_pk, raw)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/db/models/base.py", line 963, in _do_insert
    using=using, raw=raw)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/db/models/manager.py", line 85, in manager_method
    return getattr(self.get_queryset(), name)(*args, **kwargs)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/db/models/query.py", line 1076, in _insert
    return query.get_compiler(using=using).execute_sql(return_id)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/db/models/sql/compiler.py", line 1112, in execute_sql
    cursor.execute(sql, params)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/db/backends/utils.py", line 64, in execute
    return self.cursor.execute(sql, params)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/db/utils.py", line 94, in __exit__
    six.reraise(dj_exc_type, dj_exc_value, traceback)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/db/backends/utils.py", line 64, in execute
    return self.cursor.execute(sql, params)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/django/db/backends/mysql/base.py", line 101, in execute
    return self.cursor.execute(query, args)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/MySQLdb/cursors.py", line 250, in execute
    self.errorhandler(self, exc, value)
  File "/home/litmus/env/litmus/local/lib/python2.7/site-packages/MySQLdb/connections.py", line 50, in defaulterrorhandler
    raise errorvalue
DataError: (1406, "Data too long for column 'code' at row 1")
@joonas-yoon
Copy link
Member

DataError: (1406, "Data too long for column 'code' at row 1") 를 보면 code가 너무 길다고 함

class Problem(models.Model):
code = models.CharField(max_length=20, verbose_name=_('problem code'), unique=True,
help_text=_('You can only use lower case and hyphen. e.g. pr0b1em-c0de'),
validators=[RegexValidator('^[a-zA-Z0-9\-]+$', _('Problem code must be ^[a-z0-9]+$'))])

여기를 보면 코드는 최대 길이가 20자로 제한되어 있습니다.
Validator를 추가할 필요가 있어보임.

@joonas-yoon
Copy link
Member

또는 복제할 때 길이를 조정하는 것도 좋을 것 같음

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants